import { jest } from '@jest/globals'; import { PyButton } from '../../src/components/pybutton'; customElements.define('py-button', PyButton); describe('PyButton', () => { let instance: PyButton; beforeEach(() => { instance = new PyButton(); instance.runAfterRuntimeInitialized = jest.fn(); }); it('should get the Button to just instantiate', async () => { expect(instance).toBeInstanceOf(PyButton); }); it('confirm that runAfterRuntimeInitialized is called', async () => { const mockedRunAfterRuntimeInitialized = jest .spyOn(instance, 'runAfterRuntimeInitialized') .mockImplementation(jest.fn()); instance.connectedCallback(); expect(mockedRunAfterRuntimeInitialized).toHaveBeenCalled(); }); it('onCallback gets or sets a new id', async () => { expect(instance.id).toBe(''); instance.connectedCallback(); const instanceId = instance.id; // id should be similar to py-4850c8c3-d70d-d9e0-03c1-3cfeb0bcec0d-container expect(instanceId).toMatch(/py-(\w+-){1,5}container/); // calling checkId directly should return the same id instance.checkId(); expect(instance.id).toEqual(instanceId); }); it('onCallback updates on_click code and function name ', async () => { expect(instance.code).toBe(undefined); expect(instance.innerHTML).toBe(''); instance.innerHTML = '\ndef on_click(e):\n'; instance.connectedCallback(); expect(instance.code).toMatch(/def\son_click_py_(\w+)\(e\)/); expect(instance.innerHTML).toContain('