From b84552272651652ceffadd9693112893317f32fb Mon Sep 17 00:00:00 2001 From: rickstaa Date: Sun, 25 Sep 2022 17:48:40 +0200 Subject: [PATCH 1/3] ci: add e2e vercel test action This commit adds several end-to-end tests that can be used to test whether the Vercel Preview deployment successfully returns the cards. --- .github/workflows/e2e-test.yml | 20 +++++++++++++++ jest.config.js | 6 +++++ jest.e2e.config.js | 7 ++++++ package.json | 3 ++- tests/e2e/e2e.test.js | 45 ++++++++++++++++++++++++++++++++++ 5 files changed, 80 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/e2e-test.yml create mode 100644 jest.e2e.config.js create mode 100644 tests/e2e/e2e.test.js diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml new file mode 100644 index 0000000000000..4699b67d5ba15 --- /dev/null +++ b/.github/workflows/e2e-test.yml @@ -0,0 +1,20 @@ +name: Test Deployment +on: + deployment_status: + +jobs: + preview: + if: + github.event_name == 'deployment_status' && + github.event.deployment_status.state == 'success' + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - name: Install dependencies + run: npm ci + env: + CI: true + - name: Run end-to-end tests. + run: npm run test:e2e + env: + VERCEL_PREVIEW_URL: ${{ github.event.deployment_status.target_url }} diff --git a/jest.config.js b/jest.config.js index 312d88ad8e023..b4578cf5aaad5 100644 --- a/jest.config.js +++ b/jest.config.js @@ -3,4 +3,10 @@ export default { transform: {}, testEnvironment: "jsdom", coverageProvider: "v8", + testPathIgnorePatterns: ["/node_modules/", "/tests/e2e/"], + modulePathIgnorePatterns: ["/node_modules/", "/tests/e2e/"], + coveragePathIgnorePatterns: [ + "/node_modules/", + "/tests/E2E/", + ], }; diff --git a/jest.e2e.config.js b/jest.e2e.config.js new file mode 100644 index 0000000000000..656ab61f7c054 --- /dev/null +++ b/jest.e2e.config.js @@ -0,0 +1,7 @@ +export default { + clearMocks: true, + transform: {}, + testEnvironment: "node", + coverageProvider: "v8", + testMatch: ["/tests/e2e/**/*.test.js"], +}; diff --git a/package.json b/package.json index c256229340145..b1bce12bfe7bc 100644 --- a/package.json +++ b/package.json @@ -8,6 +8,7 @@ "test": "node --experimental-vm-modules node_modules/jest/bin/jest.js --coverage", "test:watch": "node --experimental-vm-modules node_modules/jest/bin/jest.js --watch", "test:update:snapshot": "node --experimental-vm-modules node_modules/jest/bin/jest.js -u", + "test:e2e": "node --experimental-vm-modules node_modules/jest/bin/jest.js --config jest.e2e.config.js", "theme-readme-gen": "node scripts/generate-theme-doc", "preview-theme": "node scripts/preview-theme", "generate-langs-json": "node scripts/generate-langs-json", @@ -17,7 +18,7 @@ "author": "Anurag Hazra", "license": "MIT", "devDependencies": { - "@actions/core": "^1.2.4", + "@actions/core": "^1.9.1", "@actions/github": "^4.0.0", "@testing-library/dom": "^8.17.1", "@testing-library/jest-dom": "^5.16.5", diff --git a/tests/e2e/e2e.test.js b/tests/e2e/e2e.test.js new file mode 100644 index 0000000000000..8df163ad4fd9a --- /dev/null +++ b/tests/e2e/e2e.test.js @@ -0,0 +1,45 @@ +/** + * @file Contains end-to-end tests for the vercel preview instance. + */ +import { describe } from "@jest/globals"; +import axios from "axios"; +import dotenv from "dotenv"; +dotenv.config(); + +describe("Fetch Cards", () => { + let VERCEL_PREVIEW_URL; + + beforeAll(() => { + VERCEL_PREVIEW_URL = process.env.VERCEL_PREVIEW_URL; + }); + + test("retrieve stats card", async () => { + expect(VERCEL_PREVIEW_URL).toBeDefined(); + await expect( + axios.get(`${VERCEL_PREVIEW_URL}/api?username=willianrod`), + ).resolves.not.toThrow(); + }); + + test("retrieve language card", async () => { + expect(VERCEL_PREVIEW_URL).toBeDefined(); + await expect( + axios.get(`${VERCEL_PREVIEW_URL}/api/top-langs/?username=willianrod`), + ).resolves.not.toThrow(); + }); + + test("retrieve WakaTime card", async () => { + expect(VERCEL_PREVIEW_URL).toBeDefined(); + await expect( + axios.get(`${VERCEL_PREVIEW_URL}/api/wakatime?username=willianrod`), + ).resolves.not.toThrow(); + }); + + test("retrieve repo card", async () => { + expect(VERCEL_PREVIEW_URL).toBeDefined(); + await expect( + axios.get( + `${VERCEL_PREVIEW_URL}/api/pin/?username=anuraghazra&repo=github-readme-stats`, + ), + ).resolves.not.toThrow(); + }); +}); From 9f638f85fa424704a6e05cd099469cbda12b07fa Mon Sep 17 00:00:00 2001 From: rickstaa Date: Tue, 27 Sep 2022 17:39:45 +0200 Subject: [PATCH 2/3] test: add additional e2e card tests --- package-lock.json | 2 +- tests/e2e/__snapshots__/e2e.test.js.snap | 674 +++++++++++++++++++++++ tests/e2e/e2e.test.js | 48 +- 3 files changed, 720 insertions(+), 4 deletions(-) create mode 100644 tests/e2e/__snapshots__/e2e.test.js.snap diff --git a/package-lock.json b/package-lock.json index 2ffe6ec9008b2..2235a4b45ac63 100644 --- a/package-lock.json +++ b/package-lock.json @@ -17,7 +17,7 @@ "word-wrap": "^1.2.3" }, "devDependencies": { - "@actions/core": "^1.2.4", + "@actions/core": "^1.9.1", "@actions/github": "^4.0.0", "@testing-library/dom": "^8.17.1", "@testing-library/jest-dom": "^5.16.5", diff --git a/tests/e2e/__snapshots__/e2e.test.js.snap b/tests/e2e/__snapshots__/e2e.test.js.snap new file mode 100644 index 0000000000000..1481b3f62e251 --- /dev/null +++ b/tests/e2e/__snapshots__/e2e.test.js.snap @@ -0,0 +1,674 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Fetch Cards retrieve WakaTime card 1`] = ` +" + + + + + + + + + + + + + Wakatime Stats + + + + + + + + + No coding activity this week + + + + + + " +`; + +exports[`Fetch Cards retrieve language card 1`] = ` +" + + + + + + + + + + + + + Most Used Languages + + + + + + + + + TypeScript + 49.46% + + + + + + + + + JavaScript + 42.83% + + + + + + + + + SCSS + 2.66% + + + + + + + + + Java + 2.61% + + + + + + + + + CSS + 2.44% + + + + + + + + + + + + + " +`; + +exports[`Fetch Cards retrieve repo card 1`] = ` +" + + + + + + + + + + + + + + + + + github-readme-stats + + + + + + + + + + ⚡ Dynamically generated stats for your github readmes + + + + + + + JavaScript + + + + + + 46.2k + + + + 11.3k + + + + + " +`; + +exports[`Fetch Cards retrieve stats card 1`] = ` +" + + Willian Rodrigues' GitHub Stats, Rank: A+ + Total Stars Earned: 57, Total Commits in 2022 : 57, Total PRs: 35, Total Issues: 10, Contributed to: 3 + + + + + + + + + + Willian Rodrigues' GitHub Stats + + + + + + + + + + + + A+ + + + + + + + + Total Stars Earned: + 57 + + + + + Total Commits (2022): + 49 + + + + + Total PRs: + 35 + + + + + Total Issues: + 10 + + + + + Contributed to: + 3 + + + + + + + " +`; diff --git a/tests/e2e/e2e.test.js b/tests/e2e/e2e.test.js index 8df163ad4fd9a..c4ead1541c72d 100644 --- a/tests/e2e/e2e.test.js +++ b/tests/e2e/e2e.test.js @@ -4,7 +4,11 @@ import { describe } from "@jest/globals"; import axios from "axios"; import dotenv from "dotenv"; + dotenv.config(); +// Script variables +const REPO = "github-readme-stats"; +const USER = "anuraghazra"; describe("Fetch Cards", () => { let VERCEL_PREVIEW_URL; @@ -15,31 +19,69 @@ describe("Fetch Cards", () => { test("retrieve stats card", async () => { expect(VERCEL_PREVIEW_URL).toBeDefined(); + + // Check if the vercel preview instance is up and running. await expect( axios.get(`${VERCEL_PREVIEW_URL}/api?username=willianrod`), ).resolves.not.toThrow(); + + // Get the vercel preview stats card response. + const serverSvg = await axios.get( + `${VERCEL_PREVIEW_URL}/api?username=willianrod`, + ); + + // Check if stats card from deployment matches the stats card from local. + expect(serverSvg.data).toMatchSnapshot(); }); test("retrieve language card", async () => { expect(VERCEL_PREVIEW_URL).toBeDefined(); + + // Check if the vercel preview instance is up and running. await expect( axios.get(`${VERCEL_PREVIEW_URL}/api/top-langs/?username=willianrod`), ).resolves.not.toThrow(); + + // Get the vercel preview stats card response. + const serverSvg = await axios.get( + `${VERCEL_PREVIEW_URL}/api/top-langs/?username=willianrod`, + ); + + // Check if stats card from deployment matches the stats card from local. + expect(serverSvg.data).toMatchSnapshot(); }); test("retrieve WakaTime card", async () => { expect(VERCEL_PREVIEW_URL).toBeDefined(); + + // Check if the vercel preview instance is up and running. await expect( axios.get(`${VERCEL_PREVIEW_URL}/api/wakatime?username=willianrod`), ).resolves.not.toThrow(); + + // Get the vercel preview stats card response. + const serverSvg = await axios.get( + `${VERCEL_PREVIEW_URL}/api/wakatime?username=willianrod`, + ); + + // Check if stats card from deployment matches the stats card from local. + expect(serverSvg.data).toMatchSnapshot(); }); test("retrieve repo card", async () => { expect(VERCEL_PREVIEW_URL).toBeDefined(); + + // Check if the vercel preview instance is up and running. await expect( - axios.get( - `${VERCEL_PREVIEW_URL}/api/pin/?username=anuraghazra&repo=github-readme-stats`, - ), + axios.get(`${VERCEL_PREVIEW_URL}/api/pin/?username=${USER}&repo=${REPO}`), ).resolves.not.toThrow(); + + // Get the vercel preview stats card response. + const serverSvg = await axios.get( + `${VERCEL_PREVIEW_URL}/api/pin/?username=${USER}&repo=${REPO}`, + ); + + // Check if stats card from deployment matches the stats card from local. + expect(serverSvg.data).toMatchSnapshot(); }); }); From 53a3a4ab2ddf57b594b587448fbd30514c6d7107 Mon Sep 17 00:00:00 2001 From: rickstaa Date: Wed, 28 Sep 2022 12:06:20 +0200 Subject: [PATCH 3/3] test: improve e2e card tests This commit makes sure that the tests also check whether a valid cards are returned from the preview deployment. --- tests/e2e/__snapshots__/e2e.test.js.snap | 674 ----------------------- tests/e2e/e2e.test.js | 146 ++++- 2 files changed, 116 insertions(+), 704 deletions(-) delete mode 100644 tests/e2e/__snapshots__/e2e.test.js.snap diff --git a/tests/e2e/__snapshots__/e2e.test.js.snap b/tests/e2e/__snapshots__/e2e.test.js.snap deleted file mode 100644 index 1481b3f62e251..0000000000000 --- a/tests/e2e/__snapshots__/e2e.test.js.snap +++ /dev/null @@ -1,674 +0,0 @@ -// Jest Snapshot v1, https://goo.gl/fbAQLP - -exports[`Fetch Cards retrieve WakaTime card 1`] = ` -" - - - - - - - - - - - - - Wakatime Stats - - - - - - - - - No coding activity this week - - - - - - " -`; - -exports[`Fetch Cards retrieve language card 1`] = ` -" - - - - - - - - - - - - - Most Used Languages - - - - - - - - - TypeScript - 49.46% - - - - - - - - - JavaScript - 42.83% - - - - - - - - - SCSS - 2.66% - - - - - - - - - Java - 2.61% - - - - - - - - - CSS - 2.44% - - - - - - - - - - - - - " -`; - -exports[`Fetch Cards retrieve repo card 1`] = ` -" - - - - - - - - - - - - - - - - - github-readme-stats - - - - - - - - - - ⚡ Dynamically generated stats for your github readmes - - - - - - - JavaScript - - - - - - 46.2k - - - - 11.3k - - - - - " -`; - -exports[`Fetch Cards retrieve stats card 1`] = ` -" - - Willian Rodrigues' GitHub Stats, Rank: A+ - Total Stars Earned: 57, Total Commits in 2022 : 57, Total PRs: 35, Total Issues: 10, Contributed to: 3 - - - - - - - - - - Willian Rodrigues' GitHub Stats - - - - - - - - - - - - A+ - - - - - - - - Total Stars Earned: - 57 - - - - - Total Commits (2022): - 49 - - - - - Total PRs: - 35 - - - - - Total Issues: - 10 - - - - - Contributed to: - 3 - - - - - - - " -`; diff --git a/tests/e2e/e2e.test.js b/tests/e2e/e2e.test.js index c4ead1541c72d..91c9c38fe83aa 100644 --- a/tests/e2e/e2e.test.js +++ b/tests/e2e/e2e.test.js @@ -1,87 +1,173 @@ /** - * @file Contains end-to-end tests for the vercel preview instance. + * @file Contains end-to-end tests for the Vercel preview instance. */ +import dotenv from "dotenv"; +dotenv.config(); + import { describe } from "@jest/globals"; import axios from "axios"; -import dotenv from "dotenv"; +import { renderRepoCard } from "../../src/cards/repo-card.js"; +import { renderStatsCard } from "../../src/cards/stats-card.js"; +import { renderTopLanguages } from "../../src/cards/top-languages-card.js"; +import { renderWakatimeCard } from "../../src/cards/wakatime-card.js"; -dotenv.config(); // Script variables -const REPO = "github-readme-stats"; -const USER = "anuraghazra"; +const REPO = "dummy-cra"; +const USER = "grsdummy"; +const STATS_DATA = { + name: "grsdummy", + totalPRs: 1, + totalCommits: 2, + totalIssues: 1, + totalStars: 1, + contributedTo: 1, + rank: { + level: "A+", + score: 51.01622937949586, + }, +}; +const LANGS_DATA = { + TypeScript: { + color: "#3178c6", + name: "TypeScript", + size: 2049, + }, + HTML: { + color: "#e34c26", + name: "HTML", + size: 1721, + }, + CSS: { + color: "#563d7c", + name: "CSS", + size: 930, + }, + Python: { + color: "#3572A5", + name: "Python", + size: 671, + }, +}; +const WAKATIME_DATA = { + human_readable_range: "last week", + is_already_updating: false, + is_coding_activity_visible: false, + is_including_today: false, + is_other_usage_visible: false, + is_stuck: false, + is_up_to_date: false, + is_up_to_date_pending_future: false, + percent_calculated: 0, + range: "last_7_days", + status: "pending_update", + timeout: 15, + username: "grsdummy", + writes_only: false, +}; +const REPOSITORY_DATA = { + name: "dummy-cra", + nameWithOwner: "grsdummy/dummy-cra", + isPrivate: false, + isArchived: false, + isTemplate: false, + stargazers: { + totalCount: 1, + }, + description: "Dummy create react app.", + primaryLanguage: { + color: "#3178c6", + id: "MDg6TGFuZ3VhZ2UyODc=", + name: "TypeScript", + }, + forkCount: 0, + starCount: 1, +}; describe("Fetch Cards", () => { let VERCEL_PREVIEW_URL; beforeAll(() => { + process.env.NODE_ENV = "development"; VERCEL_PREVIEW_URL = process.env.VERCEL_PREVIEW_URL; }); test("retrieve stats card", async () => { expect(VERCEL_PREVIEW_URL).toBeDefined(); - // Check if the vercel preview instance is up and running. + // Check if the Vercel preview instance stats card function is up and running. await expect( - axios.get(`${VERCEL_PREVIEW_URL}/api?username=willianrod`), + axios.get(`${VERCEL_PREVIEW_URL}/api?username=${USER}`), ).resolves.not.toThrow(); - // Get the vercel preview stats card response. - const serverSvg = await axios.get( - `${VERCEL_PREVIEW_URL}/api?username=willianrod`, + // Get local stats card. + const localStatsCardSVG = renderStatsCard(STATS_DATA); + + // Get the Vercel preview stats card response. + const serverStatsSvg = await axios.get( + `${VERCEL_PREVIEW_URL}/api?username=${USER}`, ); // Check if stats card from deployment matches the stats card from local. - expect(serverSvg.data).toMatchSnapshot(); + expect(serverStatsSvg.data).toEqual(localStatsCardSVG); }); test("retrieve language card", async () => { expect(VERCEL_PREVIEW_URL).toBeDefined(); - // Check if the vercel preview instance is up and running. + // Check if the Vercel preview instance language card function is up and running. await expect( - axios.get(`${VERCEL_PREVIEW_URL}/api/top-langs/?username=willianrod`), + axios.get(`${VERCEL_PREVIEW_URL}/api/top-langs/?username=${USER}`), ).resolves.not.toThrow(); - // Get the vercel preview stats card response. - const serverSvg = await axios.get( - `${VERCEL_PREVIEW_URL}/api/top-langs/?username=willianrod`, + // Get local language card. + const localLanguageCardSVG = renderTopLanguages(LANGS_DATA); + + // Get the Vercel preview language card response. + const severLanguageSVG = await axios.get( + `${VERCEL_PREVIEW_URL}/api/top-langs/?username=${USER}`, ); - // Check if stats card from deployment matches the stats card from local. - expect(serverSvg.data).toMatchSnapshot(); + // Check if language card from deployment matches the local language card. + expect(severLanguageSVG.data).toEqual(localLanguageCardSVG); }); test("retrieve WakaTime card", async () => { expect(VERCEL_PREVIEW_URL).toBeDefined(); - // Check if the vercel preview instance is up and running. + // Check if the Vercel preview instance WakaTime function is up and running. await expect( - axios.get(`${VERCEL_PREVIEW_URL}/api/wakatime?username=willianrod`), + axios.get(`${VERCEL_PREVIEW_URL}/api/wakatime?username=${USER}`), ).resolves.not.toThrow(); - // Get the vercel preview stats card response. - const serverSvg = await axios.get( - `${VERCEL_PREVIEW_URL}/api/wakatime?username=willianrod`, + // Get local WakaTime card. + const localWakaCardSVG = renderWakatimeCard(WAKATIME_DATA); + + // Get the Vercel preview WakaTime card response. + const serverWakaTimeSvg = await axios.get( + `${VERCEL_PREVIEW_URL}/api/wakatime?username=${USER}`, ); - // Check if stats card from deployment matches the stats card from local. - expect(serverSvg.data).toMatchSnapshot(); + // Check if WakaTime card from deployment matches the local WakaTime card. + expect(serverWakaTimeSvg.data).toEqual(localWakaCardSVG); }); test("retrieve repo card", async () => { expect(VERCEL_PREVIEW_URL).toBeDefined(); - // Check if the vercel preview instance is up and running. + // Check if the Vercel preview instance Repo function is up and running. await expect( axios.get(`${VERCEL_PREVIEW_URL}/api/pin/?username=${USER}&repo=${REPO}`), ).resolves.not.toThrow(); - // Get the vercel preview stats card response. - const serverSvg = await axios.get( + // Get local repo card. + const localRepoCardSVG = renderRepoCard(REPOSITORY_DATA); + + // Get the Vercel preview repo card response. + const serverRepoSvg = await axios.get( `${VERCEL_PREVIEW_URL}/api/pin/?username=${USER}&repo=${REPO}`, ); - // Check if stats card from deployment matches the stats card from local. - expect(serverSvg.data).toMatchSnapshot(); + // Check if Repo card from deployment matches the local Repo card. + expect(serverRepoSvg.data).toEqual(localRepoCardSVG); }); });