16 Commits

Author SHA1 Message Date
428a37b45c Merge pull request #11 from Mastermindzh/snyk-upgrade-f25f424214fa058139abb12ebf4797dc
[Snyk] Upgrade deepmerge from 4.2.2 to 4.3.0
2023-03-29 09:19:28 +02:00
690dc155b6 Merge pull request #10 from Mastermindzh/snyk-upgrade-57db54bc36ba2fc1090549fff202e17f
[Snyk] Upgrade styled-components from 5.3.6 to 5.3.8
2023-03-29 09:18:55 +02:00
snyk-bot
1aad1c3b9b fix: upgrade deepmerge from 4.2.2 to 4.3.0
Snyk has created this PR to upgrade deepmerge from 4.2.2 to 4.3.0.

See this package in npm:
https://www.npmjs.com/package/deepmerge

See this project in Snyk:
https://app.snyk.io/org/mastermindzh/project/1579c544-8846-4f3a-a47d-08a9afd505f2?utm_source=github&utm_medium=referral&page=upgrade-pr
2023-03-29 02:15:15 +00:00
snyk-bot
37758e337c fix: upgrade styled-components from 5.3.6 to 5.3.8
Snyk has created this PR to upgrade styled-components from 5.3.6 to 5.3.8.

See this package in npm:
https://www.npmjs.com/package/styled-components

See this project in Snyk:
https://app.snyk.io/org/mastermindzh/project/1579c544-8846-4f3a-a47d-08a9afd505f2?utm_source=github&utm_medium=referral&page=upgrade-pr
2023-03-29 02:15:10 +00:00
9ad3608d47 Merge pull request #6 from Mastermindzh/snyk-upgrade-39c364a9f908b40f696eff5a143c06b1
[Snyk] Upgrade react-router-dom from 6.4.3 to 6.8.2
2023-03-28 11:17:07 +02:00
4cb91cb798 Merge pull request #8 from Mastermindzh/snyk-upgrade-4474c14eb6d8718e035dcb986c93e236
[Snyk] Upgrade @reduxjs/toolkit from 1.9.0 to 1.9.3
2023-03-28 11:16:54 +02:00
608f2f715e Merge pull request #9 from Mastermindzh/snyk-upgrade-32e8c145d32440ab1e89e404013608ec
[Snyk] Upgrade i18next-http-backend from 2.0.1 to 2.1.1
2023-03-28 11:16:45 +02:00
snyk-bot
cbb72ebd9b fix: upgrade i18next-http-backend from 2.0.1 to 2.1.1
Snyk has created this PR to upgrade i18next-http-backend from 2.0.1 to 2.1.1.

See this package in npm:
https://www.npmjs.com/package/i18next-http-backend

See this project in Snyk:
https://app.snyk.io/org/mastermindzh/project/1579c544-8846-4f3a-a47d-08a9afd505f2?utm_source=github&utm_medium=referral&page=upgrade-pr
2023-03-28 03:24:12 +00:00
snyk-bot
4163184e58 fix: upgrade @reduxjs/toolkit from 1.9.0 to 1.9.3
Snyk has created this PR to upgrade @reduxjs/toolkit from 1.9.0 to 1.9.3.

See this package in npm:
https://www.npmjs.com/package/@reduxjs/toolkit

See this project in Snyk:
https://app.snyk.io/org/mastermindzh/project/1579c544-8846-4f3a-a47d-08a9afd505f2?utm_source=github&utm_medium=referral&page=upgrade-pr
2023-03-28 03:24:09 +00:00
snyk-bot
38b05e6429 fix: upgrade react-router-dom from 6.4.3 to 6.8.2
Snyk has created this PR to upgrade react-router-dom from 6.4.3 to 6.8.2.

See this package in npm:
https://www.npmjs.com/package/react-router-dom

See this project in Snyk:
https://app.snyk.io/org/mastermindzh/project/1579c544-8846-4f3a-a47d-08a9afd505f2?utm_source=github&utm_medium=referral&page=upgrade-pr
2023-03-28 03:24:00 +00:00
619acfad91 Merge pull request #4 from Mastermindzh/snyk-fix-15ceb24d288dc99aa169f1fe38d9993a
[Snyk] Security upgrade nginx from 1.17.3 to 1.22.1
2023-03-27 09:56:06 +02:00
snyk-bot
5ce30c3f7e fix: Dockerfile to reduce vulnerabilities
The following vulnerabilities are fixed with an upgrade:
- https://snyk.io/vuln/SNYK-DEBIAN10-APT-1049974
- https://snyk.io/vuln/SNYK-DEBIAN10-DPKG-2847944
- https://snyk.io/vuln/SNYK-DEBIAN10-FREETYPE-1019582
- https://snyk.io/vuln/SNYK-DEBIAN10-GZIP-2444259
- https://snyk.io/vuln/SNYK-DEBIAN10-LIBTASN16-3061094
2023-03-27 07:55:50 +00:00
d16e0f2726 chore: update dependencies 2022-11-08 21:35:48 +01:00
9bb18afa14 ignore oidc fetch stuff 2022-08-30 13:47:13 +02:00
f76f91e667 Added login command for cypress and SSO protected pages 2022-08-25 14:10:46 +02:00
e20fea679a Added CypressStrictMode 2022-08-15 11:51:40 +02:00
13 changed files with 5549 additions and 6410 deletions

4
.gitignore vendored
View File

@@ -70,3 +70,7 @@ bundle.zip
cypress/videos
cypress/screenshots
dist-tests/**
# ignore oidc fetch files
public/OidcServiceWorker.js
public/OidcTrustedDomains.js

View File

@@ -4,6 +4,14 @@ All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
## [0.7.0] - 2022-08-25
- Added login command for cypress and SSO protected pages
## [0.6.2] - 2022-08-15
- Added CypressStrictMode
## [0.6.1] - 2022-08-08
- eslint now receives the glob itself

View File

@@ -1,4 +1,4 @@
FROM nginx:1.17.3
FROM nginx:1.22.1
RUN mkdir -p /usr/share/nginx/html
COPY dist/ /usr/share/nginx/html

View File

@@ -13,4 +13,13 @@ export default defineConfig({
mochaFile: "dist-tests/test-results/cypress/[hash].xml",
outputs: true,
},
env: {
oidcUrl: "https://sso.mastermindzh.tech/realms/public-tests/protocol/openid-connect/token",
oidcClientId: "demo",
oidcClientSecret: "lhlPHFUd3fC1Ky0Uwyb2ssC0XiAFeGGF",
oidcGrantType: "client_credentials",
oidcScope: "openid profile email",
oidcToken: "",
oidcCallbackUrl: "http://localhost:3000/authentication/callback",
},
});

13
cypress/e2e/tenders.cy.ts Normal file
View File

@@ -0,0 +1,13 @@
describe("Tenders page", () => {
beforeEach(() => {
cy.oidcLogin();
// you can check that the user is logged in on this page:
cy.visit("http://localhost:3000");
});
it("Should navigate to tenders when clicking on Tenders", () => {
cy.get('[data-testid="nav.tenders"]').click();
cy.contains("tenders");
cy.contains("page_count");
});
});

View File

@@ -0,0 +1,41 @@
/// <reference types="cypress" />
/* eslint-disable camelcase */
import jwt_decode from "jwt-decode";
import "./../index";
Cypress.Commands.add("oidcLogin", () => {
const options = {
method: "POST",
url: Cypress.env("oidcUrl"),
form: true,
body: {
grant_type: Cypress.env("oidcGrantType"),
client_id: Cypress.env("oidcClientId"),
client_secret: Cypress.env("oidcClientSecret"),
scope: Cypress.env("oidcScope"),
},
};
return cy.request(options).then((response) => {
const { access_token, expires_in, id_token, token_type, scope } = response.body;
const accessTokenPayload = jwt_decode(access_token);
// stub email on the result, as service accounts don't generally have them but we use it in the UI
(accessTokenPayload as any).email = "cypress@e2e.email";
window.sessionStorage.setItem(
`oidc.default:${Cypress.env("oidcCallbackUrl")}`,
JSON.stringify({
tokens: {
accessToken: access_token,
expiresIn: expires_in,
idToken: id_token,
tokenType: token_type,
idTokenPayload: jwt_decode(id_token),
accessTokenPayload,
scope,
},
}),
);
return response;
});
});

View File

@@ -1,37 +0,0 @@
/// <reference types="cypress" />
// ***********************************************
// This example commands.ts shows you how to
// create various custom commands and overwrite
// existing commands.
//
// For more comprehensive examples of custom
// commands please read more here:
// https://on.cypress.io/custom-commands
// ***********************************************
//
//
// -- This is a parent command --
// Cypress.Commands.add('login', (email, password) => { ... })
//
//
// -- This is a child command --
// Cypress.Commands.add('drag', { prevSubject: 'element'}, (subject, options) => { ... })
//
//
// -- This is a dual command --
// Cypress.Commands.add('dismiss', { prevSubject: 'optional'}, (subject, options) => { ... })
//
//
// -- This will overwrite an existing command --
// Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... })
//
// declare global {
// namespace Cypress {
// interface Chainable {
// login(email: string, password: string): Chainable<void>
// drag(subject: string, options?: Partial<TypeOptions>): Chainable<Element>
// dismiss(subject: string, options?: Partial<TypeOptions>): Chainable<Element>
// visit(originalFn: CommandOriginalFn, url: string, options: Partial<VisitOptions>): Chainable<Element>
// }
// }
// }

View File

@@ -14,7 +14,5 @@
// ***********************************************************
// Import commands.js using ES2015 syntax:
import './commands'
// Alternatively you can use CommonJS syntax:
// require('./commands')
import "./index";
import "./auth/commands";

14
cypress/support/index.ts Normal file
View File

@@ -0,0 +1,14 @@
/* eslint-disable no-unused-vars */
// load type definitions that come with Cypress module
/// <reference types="cypress" />
export {};
declare global {
namespace Cypress {
interface Chainable {
/**
* Login to the oidc provider
*/
oidcLogin(): Chainable<Response<any>>;
}
}
}

11691
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -1,6 +1,6 @@
{
"name": "react-starter-kit",
"version": "0.6.1",
"version": "0.7.0",
"description": "A modern, create-react-app-based, starter kit for React projects",
"keywords": [
"react",
@@ -45,95 +45,97 @@
"*.{ts,js,jsx,tsx,css,scss,json,md}": "prettier --write"
},
"dependencies": {
"@axa-fr/react-oidc": "^6.0.0-beta10",
"@reduxjs/toolkit": "^1.8.3",
"deepmerge": "^4.2.2",
"i18next-http-backend": "^1.4.1",
"luxon": "^2.4.0",
"@axa-fr/react-oidc": "^6.10.8",
"@reduxjs/toolkit": "^1.9.3",
"deepmerge": "^4.3.0",
"i18next-http-backend": "^2.1.1",
"luxon": "^3.1.0",
"react": "^18.2.0",
"react-app-polyfill": "^3.0.0",
"react-dev-utils": "^12.0.1",
"react-dom": "^18.2.0",
"react-redux": "^8.0.2",
"react-router-dom": "^6.3.0",
"styled-components": "^5.3.5"
"react-redux": "^8.0.5",
"react-router-dom": "^6.8.2",
"styled-components": "^5.3.8"
},
"devDependencies": {
"@babel/core": "^7.18.9",
"@babel/core": "^7.20.2",
"@mastermindzh/prettier-config": "^1.0.0",
"@pmmmwh/react-refresh-webpack-plugin": "^0.5.7",
"@svgr/webpack": "^5.5.0",
"@testing-library/jest-dom": "^5.16.4",
"@testing-library/react": "^13.3.0",
"@testing-library/user-event": "^14.3.0",
"@types/jest": "^28.1.6",
"@types/luxon": "^3.0.0",
"@types/node": "^18.6.1",
"@types/react": "^18.0.15",
"@types/react-dom": "^18.0.6",
"@types/styled-components": "^5.1.25",
"babel-jest": "^27.4.2",
"babel-loader": "^8.2.5",
"@pmmmwh/react-refresh-webpack-plugin": "^0.5.8",
"@svgr/webpack": "^6.5.1",
"@testing-library/jest-dom": "^5.16.5",
"@testing-library/react": "^13.4.0",
"@testing-library/user-event": "^14.4.3",
"@types/jest": "^29.2.2",
"@types/jwt-decode": "^3.1.0",
"@types/luxon": "^3.1.0",
"@types/node": "^18.11.9",
"@types/react": "^18.0.25",
"@types/react-dom": "^18.0.8",
"@types/styled-components": "^5.1.26",
"babel-jest": "^29.3.0",
"babel-loader": "^9.1.0",
"babel-plugin-named-asset-import": "^0.3.8",
"babel-preset-react-app": "^10.0.1",
"bfj": "^7.0.2",
"browserslist": "^4.21.2",
"browserslist": "^4.21.4",
"camelcase": "^6.2.1",
"case-sensitive-paths-webpack-plugin": "^2.4.0",
"concurrently": "^7.3.0",
"concurrently": "^7.5.0",
"css-loader": "^6.7.1",
"css-minimizer-webpack-plugin": "^3.2.0",
"cypress": "^10.3.1",
"dotenv": "^10.0.0",
"dotenv-expand": "^5.1.0",
"eslint": "^8.20.0",
"css-minimizer-webpack-plugin": "^4.2.2",
"cypress": "^10.11.0",
"dotenv": "^16.0.3",
"dotenv-expand": "^9.0.0",
"eslint": "^8.27.0",
"eslint-config-prettier": "^8.5.0",
"eslint-config-react-app": "^7.0.1",
"eslint-plugin-cypress": "^2.12.1",
"eslint-plugin-import": "^2.26.0",
"eslint-plugin-react": "^7.30.1",
"eslint-plugin-react": "^7.31.10",
"eslint-watch": "^8.0.0",
"eslint-webpack-plugin": "^3.2.0",
"file-loader": "^6.2.0",
"fs-extra": "^10.1.0",
"html-webpack-plugin": "^5.5.0",
"http-proxy-middleware": "^2.0.6",
"husky": "^8.0.1",
"i18next": "^21.8.14",
"i18next-browser-languagedetector": "^6.1.4",
"husky": "^8.0.2",
"i18next": "^22.0.4",
"i18next-browser-languagedetector": "^7.0.1",
"identity-obj-proxy": "^3.0.0",
"immer": "^9.0.15",
"jest": "^27.4.3",
"jest-environment-jsdom": "^27.4.3",
"jest-junit": "^14.0.0",
"jest-resolve": "^27.4.2",
"jest-watch-typeahead": "^1.0.0",
"immer": "^9.0.16",
"jest": "^29.3.0",
"jest-environment-jsdom": "^29.3.0",
"jest-junit": "^14.0.1",
"jest-resolve": "^29.3.0",
"jest-watch-typeahead": "^2.2.0",
"jwt-decode": "^3.1.2",
"lint-staged": "^13.0.3",
"mini-css-extract-plugin": "^2.6.1",
"mocha-junit-reporter": "^2.0.2",
"postcss": "^8.4.14",
"mocha-junit-reporter": "^2.1.1",
"postcss": "^8.4.18",
"postcss-flexbugs-fixes": "^5.0.2",
"postcss-loader": "^7.0.1",
"postcss-normalize": "^10.0.1",
"postcss-preset-env": "^7.7.2",
"postcss-preset-env": "^7.8.2",
"prettier": "^2.7.1",
"pretty-quick": "^3.1.3",
"prompts": "^2.4.2",
"react-i18next": "^11.18.1",
"react-i18next": "^12.0.0",
"react-refresh": "^0.14.0",
"resolve": "^1.22.1",
"resolve-url-loader": "^4.0.0",
"sass-loader": "^12.3.0",
"semver": "^7.3.7",
"source-map-loader": "^3.0.0",
"resolve-url-loader": "^5.0.0",
"sass-loader": "^13.1.0",
"semver": "^7.3.8",
"source-map-loader": "^4.0.1",
"start-server-and-test": "^1.14.0",
"style-loader": "^3.3.1",
"terser-webpack-plugin": "^5.3.3",
"typescript": "^4.7.4",
"web-vitals": "^2.1.4",
"webpack": "^5.73.0",
"webpack-dev-server": "^4.9.3",
"webpack-manifest-plugin": "^4.0.2",
"workbox-webpack-plugin": "^6.5.3"
"terser-webpack-plugin": "^5.3.6",
"typescript": "^4.8.4",
"web-vitals": "^3.0.4",
"webpack": "^5.74.0",
"webpack-dev-server": "^4.11.1",
"webpack-manifest-plugin": "^5.0.0",
"workbox-webpack-plugin": "^6.5.4"
}
}

View File

@@ -1,9 +1,9 @@
import React from "react";
import { createRoot } from "react-dom/client";
import { Provider } from "react-redux";
import { createGlobalStyle } from "styled-components";
import App from "./App";
import { store } from "./app/store";
import { CypressStrictMode } from "./infrastructure/CypressStrictMode";
import "./infrastructure/i18n/init";
import { OidcProvider } from "./infrastructure/sso/OidcProvider";
import { Loader } from "./infrastructure/wrappers/WithPageSuspense";
@@ -27,7 +27,7 @@ const GlobalStyle = createGlobalStyle`
`;
root.render(
<React.StrictMode>
<CypressStrictMode>
<GlobalStyle />
<Provider store={store}>
<OidcProvider>
@@ -36,7 +36,7 @@ root.render(
</Loader>
</OidcProvider>
</Provider>
</React.StrictMode>,
</CypressStrictMode>,
);
// If you want to start measuring performance in your app, pass a function

View File

@@ -0,0 +1,16 @@
import React, { FunctionComponent, ReactNode } from "react";
type Props = { children?: ReactNode };
/**
* React StrictMode that disables itself when detected to be running in Cypress
*/
export const CypressStrictMode: FunctionComponent<Props> = ({ children }) => {
const isInCypress = (window as any).Cypress;
if (isInCypress) {
return <>{children}</>;
} else {
return <React.StrictMode>{children}</React.StrictMode>;
}
};