|
| 1 | +import { suite } from 'vitest'; |
1 | 2 | import p5 from '../../../src/app.js';
|
2 | 3 | import '../../js/chai_helpers';
|
3 | 4 | const toArray = (typedArray) => Array.from(typedArray);
|
@@ -2684,5 +2685,105 @@ suite('p5.RendererGL', function() {
|
2684 | 2685 | expect(logs.join('\n')).to.match(/One of the geometries has a custom vertex property 'aCustom' with fewer values than vertices./);
|
2685 | 2686 | }
|
2686 | 2687 | );
|
2687 |
| - }) |
| 2688 | + }); |
| 2689 | + |
| 2690 | + suite('Stencil Test Tracking', function() { |
| 2691 | + test('Stencil test is disabled by default', |
| 2692 | + function() { |
| 2693 | + myp5.createCanvas(50, 50, myp5.WEBGL); |
| 2694 | + const gl = myp5._renderer.GL; |
| 2695 | + const isEnabled = gl.isEnabled(gl.STENCIL_TEST); |
| 2696 | + |
| 2697 | + assert.equal(isEnabled, false); |
| 2698 | + assert.equal(myp5._renderer._userEnabledStencil, false); |
| 2699 | + } |
| 2700 | + ); |
| 2701 | + |
| 2702 | + test('Tracks when user manually enables stencil test', |
| 2703 | + function() { |
| 2704 | + myp5.createCanvas(50, 50, myp5.WEBGL); |
| 2705 | + const gl = myp5._renderer.GL; |
| 2706 | + |
| 2707 | + gl.enable(gl.STENCIL_TEST); |
| 2708 | + assert.equal(myp5._renderer._userEnabledStencil, true); |
| 2709 | + assert.equal(gl.isEnabled(gl.STENCIL_TEST), true); |
| 2710 | + } |
| 2711 | + ); |
| 2712 | + |
| 2713 | + test('Tracks when user manually disables stencil test', |
| 2714 | + function() { |
| 2715 | + myp5.createCanvas(50, 50, myp5.WEBGL); |
| 2716 | + const gl = myp5._renderer.GL; |
| 2717 | + |
| 2718 | + gl.enable(gl.STENCIL_TEST); |
| 2719 | + gl.disable(gl.STENCIL_TEST); |
| 2720 | + |
| 2721 | + assert.equal(myp5._renderer._userEnabledStencil, false); |
| 2722 | + assert.equal(gl.isEnabled(gl.STENCIL_TEST), false); |
| 2723 | + } |
| 2724 | + ); |
| 2725 | + |
| 2726 | + test('Maintains stencil test state across draw cycles when user enabled', |
| 2727 | + function() { |
| 2728 | + let drawCalled = false; |
| 2729 | + |
| 2730 | + myp5.createCanvas(50, 50, myp5.WEBGL); |
| 2731 | + const originalDraw = myp5.draw; |
| 2732 | + |
| 2733 | + myp5.draw = function() { |
| 2734 | + drawCalled = true; |
| 2735 | + if (originalDraw) originalDraw.call(myp5); |
| 2736 | + }; |
| 2737 | + |
| 2738 | + const gl = myp5._renderer.GL; |
| 2739 | + gl.enable(gl.STENCIL_TEST); |
| 2740 | + |
| 2741 | + myp5.redraw(); |
| 2742 | + |
| 2743 | + assert.equal(gl.isEnabled(gl.STENCIL_TEST), true); |
| 2744 | + assert.equal(myp5._renderer._userEnabledStencil, true); |
| 2745 | + |
| 2746 | + myp5.draw = originalDraw; |
| 2747 | + } |
| 2748 | + ); |
| 2749 | + |
| 2750 | + test('Internal clip operations preserve user stencil test setting', |
| 2751 | + function() { |
| 2752 | + myp5.createCanvas(50, 50, myp5.WEBGL); |
| 2753 | + const gl = myp5._renderer.GL; |
| 2754 | + |
| 2755 | + gl.enable(gl.STENCIL_TEST); |
| 2756 | + |
| 2757 | + myp5.push(); |
| 2758 | + myp5.clip(() => { |
| 2759 | + myp5.rect(0, 0, 10, 10); |
| 2760 | + }); |
| 2761 | + myp5.pop(); |
| 2762 | + |
| 2763 | + assert.equal(myp5._renderer._userEnabledStencil, true); |
| 2764 | + assert.equal(gl.isEnabled(gl.STENCIL_TEST), true); |
| 2765 | + } |
| 2766 | + ); |
| 2767 | + |
| 2768 | + test('Internal clip operations do not enable stencil test for future draw cycles', |
| 2769 | + function() { |
| 2770 | + myp5.createCanvas(50, 50, myp5.WEBGL); |
| 2771 | + const gl = myp5._renderer.GL; |
| 2772 | + |
| 2773 | + gl.disable(gl.STENCIL_TEST); |
| 2774 | + assert.equal(myp5._renderer._userEnabledStencil, false); |
| 2775 | + |
| 2776 | + myp5.push(); |
| 2777 | + myp5.clip(() => { |
| 2778 | + myp5.rect(0, 0, 10, 10); |
| 2779 | + }); |
| 2780 | + myp5.pop(); |
| 2781 | + |
| 2782 | + myp5.redraw(); |
| 2783 | + |
| 2784 | + assert.equal(myp5._renderer._userEnabledStencil, false); |
| 2785 | + assert.equal(gl.isEnabled(gl.STENCIL_TEST), false); |
| 2786 | + } |
| 2787 | + ); |
| 2788 | + }); |
2688 | 2789 | });
|
0 commit comments