From 231b88a2632b68067db256c1f0e632c58be28326 Mon Sep 17 00:00:00 2001 From: Thamara Andrade Date: Sun, 16 Oct 2022 22:17:45 -0300 Subject: [PATCH 1/6] Running mocha tests again --- .github/workflows/Checks.yml | 16 ++++-- package.json | 2 +- tests/main-window.js | 98 +++++++++++++++++++++--------------- 3 files changed, 71 insertions(+), 45 deletions(-) diff --git a/.github/workflows/Checks.yml b/.github/workflows/Checks.yml index dc59c94d5..449c5e6be 100644 --- a/.github/workflows/Checks.yml +++ b/.github/workflows/Checks.yml @@ -24,6 +24,9 @@ jobs: sudo chmod +x /tmp/chromedriver/chromedriver /tmp/chromedriver/chromedriver & sudo Xvfb -ac :99 -screen 0 1280x1024x24 > /dev/null 2>&1 & + - name: ' Create COV_REPORT' + run: | + mkdir COV_REPORT - name: ' Tests' shell: bash env: @@ -31,16 +34,21 @@ jobs: run: | npm ci npm run test:jest - - name: ' Create COV_REPORT' - run: | - mkdir COV_REPORT - name: ' Copy jest results' run: | cp coverage_jest/coverage-final.json COV_REPORT/coverage-final-jest.json + - name: ' Tests - Mocha' + run: npm run test:mocha + shell: bash + if: matrix.os == 'ubuntu-latest' + - name: ' Copy mocha results' + run: | + cp coverage_jest/coverage-final.json COV_REPORT/coverage-final-mocha.json + if: matrix.os == 'ubuntu-latest' - name: ' CodeCov' uses: codecov/codecov-action@v2 with: token: ${{ secrets.CODECOV_TOKEN }} - files: COV_REPORT/coverage-final-jest.json + files: COV_REPORT/coverage-final-*.json name: codecov-${{ matrix.os }} verbose: true \ No newline at end of file diff --git a/package.json b/package.json index d4d0d510d..2a8eaee34 100644 --- a/package.json +++ b/package.json @@ -33,7 +33,7 @@ "start": "electron .", "test": "npm-run-all test:*", "test:jest": "jest --runInBand --detectOpenHandles --verbose --colors", - "test:mocha": "nyc --reporter=lcov --reporter=json mocha tests/*" + "test:mocha": "nyc --reporter=lcov --reporter=json mocha tests/* --bail" }, "pre-commit": [ "clean", diff --git a/tests/main-window.js b/tests/main-window.js index 08a5c2300..1eab5badc 100644 --- a/tests/main-window.js +++ b/tests/main-window.js @@ -10,64 +10,67 @@ process.env.NODE_ENV = 'test'; const months = [ 'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December' ]; const weekDay = [ 'Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday' ]; +function log(msg) +{ + console.log(`${(new Date()).toISOString().substr(0, 19)}: ${msg}`); +} + describe('Application launch', function() { - // deepcode ignore UseArrowFunction: => will not work on here - beforeEach(function() + this.timeout(30000); + this.beforeEach(async function() { - this.timeout(25000); // Estimated pessimistic time taken for the app to the brought up in CI this.app = new Application({ path: electronPath, - args: [path.join(__dirname, '..')] + args: [path.join(__dirname, '..')], + waitTimeout: 30000, + quitTimeout: 1000 }); - return this.app.start(); + log('Start app...') + await this.app.start(); + log('App started.') }); - afterEach(function() + this.afterEach(async function() { - this.timeout(10000); // Estimated pessimistic time taken for the app to be stopped in CI + this.timeout(30000); + log(`App is running: ${this.app && this.app.isRunning()}`) if (this.app && this.app.isRunning()) { - return this.app.stop(); + log('Stop app...'); + await this.app.stop(); + log('App stoped'); } }); it('App opens correctly', async function() { + log('Running test ' + this.test.title); const { client, browserWindow } = this.app; - await client.waitUntilWindowLoaded(); + await client.waitUntilWindowLoaded(10000); const title = await browserWindow.getTitle(); assert.equal(title, 'Time to Leave'); + log('Running test - Done'); }); it('Calendar opens on Current Month/Year', async function() { + log('Running test ' + this.test.title); const { client } = this.app; - await client.waitUntilWindowLoaded(); + await client.waitUntilWindowLoaded(10000); const monthYear = await client.$('#month-year'); const monthYearText = await monthYear.getText(); const today = new Date(); assert.equal(monthYearText, `${months[today.getMonth()]} ${today.getFullYear()}`); - }); - - it('Change to Day View', async function() - { - const { client } = this.app; - await client.waitUntilWindowLoaded(); - - const switchViewBtn = await client.$('#switch-view'); - await switchViewBtn.click(); - const headerDate = await client.$('#header-date'); - const headerDateText = await headerDate.getText(); - const today = new Date(); - assert.equal(headerDateText, `${weekDay[today.getDay()]}, ${months[today.getMonth()]} ${today.getDate()}, ${today.getFullYear()}`); + log('Running test - Done'); }); it('Calendar change to previous Month', async function() { + log('Running test ' + this.test.title); const { client } = this.app; - await client.waitUntilWindowLoaded(); + await client.waitUntilWindowLoaded(10000); const prevMonth = await client.$('#prev-month'); prevMonth.click(); @@ -76,12 +79,14 @@ describe('Application launch', function() const today = new Date(); const prevMonthDate = new Date(today.getFullYear(), today.getMonth(), -1); assert.equal(monthYearText, `${months[prevMonthDate.getMonth()]} ${prevMonthDate.getFullYear()}`); + log('Running test - Done'); }); it('Calendar change to next Month', async function() { + log('Running test ' + this.test.title); const { client } = this.app; - await client.waitUntilWindowLoaded(); + await client.waitUntilWindowLoaded(10000); const nextMonth = await client.$('#next-month'); nextMonth.click(); @@ -90,35 +95,48 @@ describe('Application launch', function() const today = new Date(); const nextMonthDate = new Date(today.getFullYear(), today.getMonth() + 1, 1); assert.equal(monthYearText, `${months[nextMonthDate.getMonth()]} ${nextMonthDate.getFullYear()}`); + log('Running test - Done'); }); - it('Calendar change to pervious Day', async function() + it('Day View - Current, yesterday and tomorrow', async function() { + log('Running test ' + this.test.title); const { client } = this.app; - await client.waitUntilWindowLoaded(); + await client.waitUntilWindowLoaded(10000); + + // Switch to Day View const switchViewBtn = await client.$('#switch-view'); await switchViewBtn.click(); + + // Check that changed to current day + let headerDate = await client.$('#header-date'); + let headerDateText = await headerDate.getText(); + const today = new Date(); + assert.equal(headerDateText, `${weekDay[today.getDay()]}, ${months[today.getMonth()]} ${today.getDate()}, ${today.getFullYear()}`); + + // Check that prev day go back to yesterday const prevDay = await client.$('#prev-day'); prevDay.click(); - const headerDate = await client.$('#header-date'); - const headerDateText = await headerDate.getText(); - const today = new Date(); + headerDate = await client.$('#header-date'); + headerDateText = await headerDate.getText(); const previousDayDate = new Date(today.getFullYear(), today.getMonth(), today.getDate() - 1); assert.equal(headerDateText, `${weekDay[previousDayDate.getDay()]}, ${months[previousDayDate.getMonth()]} ${previousDayDate.getDate()}, ${previousDayDate.getFullYear()}`); - }); - it('Calendar change to next Day', async function() - { - const { client } = this.app; - await client.waitUntilWindowLoaded(); - const switchViewBtn = await client.$('#switch-view'); - await switchViewBtn.click(); + // Back to current day + const currentDay = await client.$('#current-day'); + currentDay.click(); + headerDate = await client.$('#header-date'); + headerDateText = await headerDate.getText(); + assert.equal(headerDateText, `${weekDay[today.getDay()]}, ${months[today.getMonth()]} ${today.getDate()}, ${today.getFullYear()}`); + + // Check that next day go back to tomorrow const nextDay = await client.$('#next-day'); nextDay.click(); - const headerDate = await client.$('#header-date'); - const headerDateText = await headerDate.getText(); - const today = new Date(); + headerDate = await client.$('#header-date'); + headerDateText = await headerDate.getText(); const nextDayDate = new Date(today.getFullYear(), today.getMonth(), today.getDate() + 1); assert.equal(headerDateText, `${weekDay[nextDayDate.getDay()]}, ${months[nextDayDate.getMonth()]} ${nextDayDate.getDate()}, ${nextDayDate.getFullYear()}`); + + log('Running test - Done'); }); }); From 1528406779b8f16938cf44e1d89c7370006d5698 Mon Sep 17 00:00:00 2001 From: Thamara Andrade Date: Tue, 25 Oct 2022 01:20:45 -0300 Subject: [PATCH 2/6] Setting an ignorant timeout --- tests/main-window.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/main-window.js b/tests/main-window.js index 1eab5badc..8644a8461 100644 --- a/tests/main-window.js +++ b/tests/main-window.js @@ -17,7 +17,7 @@ function log(msg) describe('Application launch', function() { - this.timeout(30000); + this.timeout(60000); this.beforeEach(async function() { this.app = new Application({ From 1d2e734f5a4a868147c68868a4b2d3390fe3b12c Mon Sep 17 00:00:00 2001 From: Thamara Andrade Date: Tue, 25 Oct 2022 01:37:08 -0300 Subject: [PATCH 3/6] Setting an (even more) ignorant timeout --- tests/main-window.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/tests/main-window.js b/tests/main-window.js index 8644a8461..1be52e597 100644 --- a/tests/main-window.js +++ b/tests/main-window.js @@ -20,6 +20,7 @@ describe('Application launch', function() this.timeout(60000); this.beforeEach(async function() { + this.timeout(60000); this.app = new Application({ path: electronPath, args: [path.join(__dirname, '..')], @@ -33,7 +34,7 @@ describe('Application launch', function() this.afterEach(async function() { - this.timeout(30000); + this.timeout(60000); log(`App is running: ${this.app && this.app.isRunning()}`) if (this.app && this.app.isRunning()) { From ef1c919b90beaccefe26e6dc2f12e6a9be237cf4 Mon Sep 17 00:00:00 2001 From: Thamara Andrade Date: Tue, 25 Oct 2022 01:42:13 -0300 Subject: [PATCH 4/6] Removing wait until window loaded timeout --- tests/main-window.js | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/tests/main-window.js b/tests/main-window.js index 1be52e597..05bcf0710 100644 --- a/tests/main-window.js +++ b/tests/main-window.js @@ -48,7 +48,7 @@ describe('Application launch', function() { log('Running test ' + this.test.title); const { client, browserWindow } = this.app; - await client.waitUntilWindowLoaded(10000); + await client.waitUntilWindowLoaded(); const title = await browserWindow.getTitle(); assert.equal(title, 'Time to Leave'); log('Running test - Done'); @@ -58,7 +58,7 @@ describe('Application launch', function() { log('Running test ' + this.test.title); const { client } = this.app; - await client.waitUntilWindowLoaded(10000); + await client.waitUntilWindowLoaded(); const monthYear = await client.$('#month-year'); const monthYearText = await monthYear.getText(); @@ -71,7 +71,7 @@ describe('Application launch', function() { log('Running test ' + this.test.title); const { client } = this.app; - await client.waitUntilWindowLoaded(10000); + await client.waitUntilWindowLoaded(); const prevMonth = await client.$('#prev-month'); prevMonth.click(); @@ -87,7 +87,7 @@ describe('Application launch', function() { log('Running test ' + this.test.title); const { client } = this.app; - await client.waitUntilWindowLoaded(10000); + await client.waitUntilWindowLoaded(); const nextMonth = await client.$('#next-month'); nextMonth.click(); @@ -103,7 +103,7 @@ describe('Application launch', function() { log('Running test ' + this.test.title); const { client } = this.app; - await client.waitUntilWindowLoaded(10000); + await client.waitUntilWindowLoaded(); // Switch to Day View const switchViewBtn = await client.$('#switch-view'); From c7a7ca06a51f07c5aa0b0fa6f68405502620f7b7 Mon Sep 17 00:00:00 2001 From: Thamara Andrade Date: Tue, 25 Oct 2022 01:43:30 -0300 Subject: [PATCH 5/6] Move wait to beforeEach --- tests/main-window.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/tests/main-window.js b/tests/main-window.js index 05bcf0710..4e2c2e7be 100644 --- a/tests/main-window.js +++ b/tests/main-window.js @@ -29,6 +29,8 @@ describe('Application launch', function() }); log('Start app...') await this.app.start(); + const { client } = this.app; + await client.waitUntilWindowLoaded(); log('App started.') }); From 21f83bdd4745e2a4a6895199de83a04bc4731645 Mon Sep 17 00:00:00 2001 From: Thamara Andrade Date: Tue, 25 Oct 2022 01:54:06 -0300 Subject: [PATCH 6/6] Running mocha tests in parallel --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 2a8eaee34..a1365bf76 100644 --- a/package.json +++ b/package.json @@ -33,7 +33,7 @@ "start": "electron .", "test": "npm-run-all test:*", "test:jest": "jest --runInBand --detectOpenHandles --verbose --colors", - "test:mocha": "nyc --reporter=lcov --reporter=json mocha tests/* --bail" + "test:mocha": "nyc --reporter=lcov --reporter=json mocha tests/* --bail -p" }, "pre-commit": [ "clean",