|
1 |
| -// const { _electron: electron } = require('playwright'); |
2 |
| -// const { test, expect } = require('@playwright/test'); |
3 |
| - |
4 |
| -// test('Launch Electron app, select device, toggle ACPU power, click Clocking, Add clock source, and submit form', async () => { |
5 |
| -// const app = await electron.launch({ args: ['main.js'] }); |
6 |
| -// const window = await app.firstWindow(); |
7 |
| - |
8 |
| -// // Selecting the device (MPW1 Gemini) |
9 |
| -// const deviceDropdown = await window.waitForSelector('#deviceId'); |
10 |
| -// await deviceDropdown.selectOption('MPW1'); |
11 |
| -// await new Promise((resolve) => setTimeout(resolve, 2000)); // Wait for 2 seconds |
12 |
| - |
13 |
| -// // Selecting Clocking block |
14 |
| -// const clockingBlockSelector = '#app > div > div.top-row-container > div.main-table-container.main-border > div.top-l2 > div.top-l2-col2 > div.top-l2-col2-elem > div > div:nth-child(2) > div:nth-child(1) > div'; |
15 |
| -// const clockingBlock = await window.waitForSelector(clockingBlockSelector); |
16 |
| -// await clockingBlock.click(); |
17 |
| -// await new Promise((resolve) => setTimeout(resolve, 2000)); // Wait for 2 seconds |
18 |
| - |
19 |
| -// // Clicking on Add button |
20 |
| -// const addButtonSelector = '#app > div > div.table-container.main-border > div > div.power-and-table-wrapper > div.table-wrapper > button'; |
21 |
| -// const addButton = await window.waitForSelector(addButtonSelector); |
22 |
| -// await addButton.click(); |
23 |
| -// await new Promise((resolve) => setTimeout(resolve, 2000)); // Wait for 2 seconds |
24 |
| - |
25 |
| -// // Ensure modal is visible before interacting |
26 |
| -// const modalSelector = 'body > div:nth-child(3) > div > div.ant-modal-wrap > div'; |
27 |
| -// await window.waitForSelector(modalSelector, { state: 'visible', timeout: 5000 }); // Wait for modal |
28 |
| - |
29 |
| -// // Typing description as 'test' |
30 |
| -// const descriptionSelector = 'body > div:nth-child(3) > div > div.ant-modal-wrap > div > div:nth-child(1) > div > div.ant-modal-body > div > form > div:nth-child(2) > input[type=text]'; |
31 |
| -// const descriptionInput = await window.waitForSelector(descriptionSelector); |
32 |
| -// await descriptionInput.click(); |
33 |
| -// await descriptionInput.fill('test'); |
34 |
| -// await new Promise((resolve) => setTimeout(resolve, 1000)); // Wait for 1 second |
35 |
| - |
36 |
| -// // Typing Port/Signal name as 'test' |
37 |
| -// const portSignalSelector = 'body > div:nth-child(3) > div > div.ant-modal-wrap > div > div:nth-child(1) > div > div.ant-modal-body > div > form > div:nth-child(3) > input[type=text]'; |
38 |
| -// const portSignalInput = await window.waitForSelector(portSignalSelector); |
39 |
| -// await portSignalInput.click(); |
40 |
| -// await portSignalInput.fill('test'); |
41 |
| -// await new Promise((resolve) => setTimeout(resolve, 1000)); // Wait for 1 second |
42 |
| - |
43 |
| -// // Clicking OK to submit the form |
44 |
| -// const okButtonSelector = 'body > div:nth-child(3) > div > div.ant-modal-wrap > div > div:nth-child(1) > div > div.ant-modal-footer > button.ant-btn.css-dev-only-do-not-override-apn68.ant-btn-primary.ant-btn-color-primary.ant-btn-variant-solid'; |
45 |
| -// const okButton = await window.waitForSelector(okButtonSelector); |
46 |
| -// await okButton.click(); |
47 |
| - |
48 |
| -// // Closing the test |
49 |
| -// await app.close(); |
50 |
| -// }); |
| 1 | +const { _electron: electron } = require('playwright'); |
| 2 | +const { test, expect } = require('@playwright/test'); |
| 3 | + |
| 4 | +test('Launch Electron app, select device, toggle ACPU power, click Clocking, Add clock source, and submit form', async () => { |
| 5 | + const app = await electron.launch({ args: ['main.js'] }); |
| 6 | + const window = await app.firstWindow(); |
| 7 | + |
| 8 | + // Selecting the device (MPW1 Gemini) |
| 9 | + const deviceDropdown = await window.waitForSelector('#deviceId'); |
| 10 | + await deviceDropdown.selectOption('MPW1'); |
| 11 | + await new Promise((resolve) => setTimeout(resolve, 2000)); // Wait for 2 seconds |
| 12 | + |
| 13 | + // Selecting Clocking block |
| 14 | + const clockingBlockSelector = '#app > div > div.top-row-container > div.main-table-container.main-border > div.top-l2 > div.top-l2-col2 > div.top-l2-col2-elem > div > div:nth-child(2) > div:nth-child(1) > div'; |
| 15 | + const clockingBlock = await window.waitForSelector(clockingBlockSelector); |
| 16 | + await clockingBlock.click(); |
| 17 | + await new Promise((resolve) => setTimeout(resolve, 2000)); // Wait for 2 seconds |
| 18 | + |
| 19 | + // Clicking on Add button |
| 20 | + const addButtonSelector = '#app > div > div.table-container.main-border > div > div.power-and-table-wrapper > div.table-wrapper > button'; |
| 21 | + const addButton = await window.waitForSelector(addButtonSelector); |
| 22 | + await addButton.click(); |
| 23 | + await new Promise((resolve) => setTimeout(resolve, 2000)); // Wait for 2 seconds |
| 24 | + |
| 25 | + // Ensure modal is visible before interacting |
| 26 | + const modalSelector = 'body > div:nth-child(3) > div > div.ant-modal-wrap > div'; |
| 27 | + await window.waitForSelector(modalSelector, { state: 'visible', timeout: 5000 }); // Wait for modal |
| 28 | + |
| 29 | + // Typing description as 'test' |
| 30 | + const descriptionSelector = 'body > div:nth-child(3) > div > div.ant-modal-wrap > div > div:nth-child(1) > div > div.ant-modal-body > div > form > div:nth-child(2) > input[type=text]'; |
| 31 | + const descriptionInput = await window.waitForSelector(descriptionSelector); |
| 32 | + await descriptionInput.click(); |
| 33 | + await descriptionInput.fill('test'); |
| 34 | + await new Promise((resolve) => setTimeout(resolve, 1000)); // Wait for 1 second |
| 35 | + |
| 36 | + // Typing Port/Signal name as 'test' |
| 37 | + const portSignalSelector = 'body > div:nth-child(3) > div > div.ant-modal-wrap > div > div:nth-child(1) > div > div.ant-modal-body > div > form > div:nth-child(3) > input[type=text]'; |
| 38 | + const portSignalInput = await window.waitForSelector(portSignalSelector); |
| 39 | + await portSignalInput.click(); |
| 40 | + await portSignalInput.fill('test'); |
| 41 | + await new Promise((resolve) => setTimeout(resolve, 1000)); // Wait for 1 second |
| 42 | + |
| 43 | + // Clicking OK to submit the form |
| 44 | + const okButtonSelector = 'body > div:nth-child(3) > div > div.ant-modal-wrap > div > div:nth-child(1) > div > div.ant-modal-footer > button.ant-btn.css-dev-only-do-not-override-49qm.ant-btn-primary.ant-btn-color-primary.ant-btn-variant-solid > span'; |
| 45 | + const okButton = await window.waitForSelector(okButtonSelector); |
| 46 | + await okButton.click(); |
| 47 | + |
| 48 | + // Closing the test |
| 49 | + await app.close(); |
| 50 | +}); |
51 | 51 |
|
0 commit comments