@centreon/js-config 24.4.12 → 24.4.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4,8 +4,11 @@
4
4
  import { execSync } from 'child_process';
5
5
 
6
6
  import { defineConfig } from 'cypress';
7
+ import installLogsPrinter from 'cypress-terminal-report/src/installLogsPrinter';
7
8
 
8
- import setupNodeEvents from './plugins';
9
+ import esbuildPreprocessor from './esbuild-preprocessor';
10
+ import plugins from './plugins';
11
+ import tasks from './tasks';
9
12
 
10
13
  interface ConfigurationOptions {
11
14
  cypressFolder?: string;
@@ -22,9 +25,7 @@ export default ({
22
25
  dockerName,
23
26
  env
24
27
  }: ConfigurationOptions): Cypress.ConfigOptions => {
25
- const resultsFolder = `${cypressFolder || 'cypress'}/results${
26
- isDevelopment ? '/dev' : ''
27
- }`;
28
+ const resultsFolder = `${cypressFolder || '.'}/results`;
28
29
 
29
30
  const webImageVersion = execSync('git rev-parse --abbrev-ref HEAD')
30
31
  .toString('utf8')
@@ -35,8 +36,20 @@ export default ({
35
36
  defaultCommandTimeout: 6000,
36
37
  e2e: {
37
38
  excludeSpecPattern: ['*.js', '*.ts', '*.md'],
38
- setupNodeEvents,
39
- specPattern
39
+ fixturesFolder: 'fixtures',
40
+ reporter: require.resolve('cypress-multi-reporters'),
41
+ reporterOptions: {
42
+ configFile: `${__dirname}/reporter-config.js`
43
+ },
44
+ setupNodeEvents: async (on, config) => {
45
+ installLogsPrinter(on);
46
+ await esbuildPreprocessor(on, config);
47
+ tasks(on);
48
+
49
+ return plugins(on, config);
50
+ },
51
+ specPattern,
52
+ supportFile: 'support/e2e.{js,jsx,ts,tsx}'
40
53
  },
41
54
  env: {
42
55
  ...env,
@@ -45,34 +58,12 @@ export default ({
45
58
  WEB_IMAGE_VERSION: webImageVersion,
46
59
  dockerName: dockerName || 'centreon-dev'
47
60
  },
48
- execTimeout: 120000,
49
- reporter: 'mochawesome',
50
- reporterOptions: {
51
- html: false,
52
- json: true,
53
- overwrite: true,
54
- reportDir: `${resultsFolder}/reports`,
55
- reportFilename: '[name]-report.json'
56
- },
61
+ execTimeout: 60000,
57
62
  requestTimeout: 10000,
58
63
  retries: 0,
59
64
  screenshotsFolder: `${resultsFolder}/screenshots`,
60
- setupNodeEvents: (on, config) => {
61
- on('before:browser:launch', (browser, launchOptions) => {
62
- if (browser.name === 'chrome' && browser.isHeadless) {
63
- launchOptions.args = launchOptions.args.map((arg) => {
64
- if (arg === '--headless') {
65
- return '--headless=new';
66
- }
67
-
68
- return arg;
69
- });
70
- }
71
-
72
- return launchOptions;
73
- });
74
- },
75
65
  video: true,
66
+ videoCompression: 0,
76
67
  videosFolder: `${resultsFolder}/videos`
77
68
  });
78
69
  };
@@ -0,0 +1,26 @@
1
+ import { NodeGlobalsPolyfillPlugin } from '@esbuild-plugins/node-globals-polyfill';
2
+ import { NodeModulesPolyfillPlugin } from '@esbuild-plugins/node-modules-polyfill';
3
+ import { addCucumberPreprocessorPlugin } from '@badeball/cypress-cucumber-preprocessor';
4
+ import createBundler from '@bahmutov/cypress-esbuild-preprocessor';
5
+ import createEsbuildPlugin from '@badeball/cypress-cucumber-preprocessor/esbuild';
6
+
7
+ export default async (
8
+ on: Cypress.PluginEvents,
9
+ config: Cypress.PluginConfigOptions
10
+ ): Promise<void> => {
11
+ await addCucumberPreprocessorPlugin(on, config);
12
+
13
+ on(
14
+ 'file:preprocessor',
15
+ createBundler({
16
+ plugins: [
17
+ createEsbuildPlugin(config),
18
+ NodeModulesPolyfillPlugin(),
19
+ NodeGlobalsPolyfillPlugin({
20
+ buffer: true,
21
+ process: true
22
+ })
23
+ ]
24
+ })
25
+ );
26
+ };
@@ -3,132 +3,34 @@
3
3
  /* eslint-disable @typescript-eslint/no-var-requires */
4
4
  /* eslint-disable no-param-reassign */
5
5
 
6
- import Docker from 'dockerode';
7
- import { addCucumberPreprocessorPlugin } from '@badeball/cypress-cucumber-preprocessor';
8
- import webpackPreprocessor from '@cypress/webpack-preprocessor';
9
-
10
- const docker = new Docker();
11
-
12
- const getWebpackOptions = (config): object => {
13
- return {
14
- module: {
15
- rules: [
16
- {
17
- exclude: [/node_modules/],
18
- test: /\.ts?$/,
19
- use: [
20
- {
21
- loader: 'swc-loader'
22
- }
23
- ]
24
- },
25
- {
26
- test: /\.feature$/,
27
- use: [
28
- {
29
- loader: '@badeball/cypress-cucumber-preprocessor/webpack',
30
- options: config
31
- }
32
- ]
33
- }
34
- ]
35
- },
36
- resolve: {
37
- extensions: ['.ts', '.js']
38
- }
39
- };
40
- };
41
-
42
- export default async (on, config): Promise<void> => {
43
- await addCucumberPreprocessorPlugin(on, config);
6
+ export default (
7
+ on: Cypress.PluginEvents,
8
+ config: Cypress.PluginConfigOptions
9
+ ): Cypress.PluginConfigOptions => {
10
+ on('before:browser:launch', (browser, launchOptions) => {
11
+ const width = 1920;
12
+ const height = 1080;
13
+
14
+ if (browser.name === 'chrome') {
15
+ if (browser.isHeadless) {
16
+ launchOptions.args.push('--headless=new');
17
+ }
44
18
 
45
- const webpackOptions = await getWebpackOptions(config);
46
- const options = {
47
- webpackOptions
48
- };
19
+ // flags description : https://github.com/GoogleChrome/chrome-launcher/blob/main/docs/chrome-flags-for-tools.md
20
+ launchOptions.args.push('--disable-gpu');
21
+ launchOptions.args.push('--auto-open-devtools-for-tabs');
22
+ launchOptions.args.push('--disable-extensions');
23
+ launchOptions.args.push('--hide-scrollbars');
24
+ launchOptions.args.push('--mute-audio');
49
25
 
50
- on('file:preprocessor', webpackPreprocessor(options));
26
+ launchOptions.args.push(`--window-size=${width},${height}`);
51
27
 
52
- on('before:browser:launch', (browser = {}, launchOptions) => {
53
- if ((browser as { name }).name === 'chrome') {
54
- launchOptions.args.push('--disable-gpu');
55
- launchOptions.args = launchOptions.args.filter(
56
- (element) => element !== '--disable-dev-shm-usage'
57
- );
28
+ // force screen to be non-retina and just use our given resolution
29
+ launchOptions.args.push('--force-device-scale-factor=1');
58
30
  }
59
31
 
60
32
  return launchOptions;
61
33
  });
62
34
 
63
- interface PortBinding {
64
- destination: number;
65
- source: number;
66
- }
67
-
68
- interface StartContainerProps {
69
- image: string;
70
- name: string;
71
- portBindings: Array<PortBinding>;
72
- }
73
-
74
- interface StopContainerProps {
75
- name: string;
76
- }
77
-
78
- on('task', {
79
- startContainer: async ({
80
- image,
81
- name,
82
- portBindings = []
83
- }: StartContainerProps) => {
84
- const webContainers = await docker.listContainers({
85
- all: true,
86
- filters: { name: [name] }
87
- });
88
- if (webContainers.length) {
89
- return webContainers[0];
90
- }
91
-
92
- const container = await docker.createContainer({
93
- AttachStderr: true,
94
- AttachStdin: false,
95
- AttachStdout: true,
96
- ExposedPorts: portBindings.reduce((accumulator, currentValue) => {
97
- accumulator[`${currentValue.source}/tcp`] = {};
98
-
99
- return accumulator;
100
- }, {}),
101
- HostConfig: {
102
- PortBindings: portBindings.reduce((accumulator, currentValue) => {
103
- accumulator[`${currentValue.source}/tcp`] = [
104
- {
105
- HostIP: '0.0.0.0',
106
- HostPort: `${currentValue.destination}`
107
- }
108
- ];
109
-
110
- return accumulator;
111
- }, {})
112
- },
113
- Image: image,
114
- OpenStdin: false,
115
- StdinOnce: false,
116
- Tty: true,
117
- name
118
- });
119
-
120
- await container.start();
121
-
122
- return container;
123
- },
124
- stopContainer: async ({ name }: StopContainerProps) => {
125
- const container = await docker.getContainer(name);
126
- await container.kill();
127
- await container.remove();
128
-
129
- return null;
130
- }
131
- });
132
-
133
35
  return config;
134
36
  };
@@ -0,0 +1,13 @@
1
+ module.exports = {
2
+ mochawesomeReporterOptions: {
3
+ consoleReporter: 'none',
4
+ html: false,
5
+ json: true,
6
+ overwrite: true,
7
+ reportDir: 'results/reports',
8
+ reportFilename: '[name]-report.json'
9
+ },
10
+ reporterEnabled: `mochawesome,${require.resolve(
11
+ '@badeball/cypress-cucumber-preprocessor/pretty-reporter'
12
+ )}`
13
+ };
@@ -0,0 +1,105 @@
1
+ import { execSync } from 'child_process';
2
+ import { existsSync, mkdirSync } from 'fs';
3
+
4
+ import Docker from 'dockerode';
5
+
6
+ export default (on: Cypress.PluginEvents): void => {
7
+ const docker = new Docker();
8
+
9
+ interface PortBinding {
10
+ destination: number;
11
+ source: number;
12
+ }
13
+
14
+ interface StartContainerProps {
15
+ image: string;
16
+ name: string;
17
+ portBindings: Array<PortBinding>;
18
+ }
19
+
20
+ interface StopContainerProps {
21
+ name: string;
22
+ }
23
+
24
+ on('task', {
25
+ createDirectory: async (directoryPath: string) => {
26
+ if (!existsSync(directoryPath)) {
27
+ mkdirSync(directoryPath, { recursive: true });
28
+ }
29
+
30
+ return null;
31
+ },
32
+ startContainer: async ({
33
+ image,
34
+ name,
35
+ portBindings = []
36
+ }: StartContainerProps) => {
37
+ const imageList = execSync(
38
+ 'docker image list --format "{{.Repository}}:{{.Tag}}"'
39
+ ).toString('utf8');
40
+
41
+ if (
42
+ !imageList.match(
43
+ new RegExp(
44
+ `^${image.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&')}`,
45
+ 'm'
46
+ )
47
+ )
48
+ ) {
49
+ execSync(`docker pull ${image}`);
50
+ }
51
+
52
+ const webContainers = await docker.listContainers({
53
+ all: true,
54
+ filters: { name: [name] }
55
+ });
56
+ if (webContainers.length) {
57
+ return webContainers[0];
58
+ }
59
+
60
+ const container = await docker.createContainer({
61
+ AttachStderr: true,
62
+ AttachStdin: false,
63
+ AttachStdout: true,
64
+ ExposedPorts: portBindings.reduce((accumulator, currentValue) => {
65
+ accumulator[`${currentValue.source}/tcp`] = {};
66
+
67
+ return accumulator;
68
+ }, {}),
69
+ HostConfig: {
70
+ PortBindings: portBindings.reduce((accumulator, currentValue) => {
71
+ accumulator[`${currentValue.source}/tcp`] = [
72
+ {
73
+ HostIP: '127.0.0.1',
74
+ HostPort: `${currentValue.destination}`
75
+ }
76
+ ];
77
+
78
+ return accumulator;
79
+ }, {})
80
+ },
81
+ Image: image,
82
+ OpenStdin: false,
83
+ StdinOnce: false,
84
+ Tty: true,
85
+ name
86
+ });
87
+
88
+ await container.start();
89
+
90
+ return container;
91
+ },
92
+ stopContainer: async ({ name }: StopContainerProps) => {
93
+ const container = await docker.getContainer(name);
94
+ await container.kill();
95
+ await container.remove();
96
+
97
+ return null;
98
+ },
99
+ waitOn: async (url: string) => {
100
+ execSync(`npx wait-on ${url}`);
101
+
102
+ return null;
103
+ }
104
+ });
105
+ };
@@ -21,11 +21,15 @@ module.exports = {
21
21
  }
22
22
  ],
23
23
  '@typescript-eslint/camelcase': 'off',
24
- '@typescript-eslint/consistent-type-definitions': [
24
+ '@typescript-eslint/consistent-type-definitions': ['off', 'interface'],
25
+ '@typescript-eslint/explicit-function-return-type': [
25
26
  'error',
26
- 'interface'
27
+ {
28
+ allowExpressions: true,
29
+ allowHigherOrderFunctions: true,
30
+ allowTypedFunctionExpressions: true
31
+ }
27
32
  ],
28
- '@typescript-eslint/explicit-function-return-type': ['error'],
29
33
  '@typescript-eslint/explicit-member-accessibility': [
30
34
  'error',
31
35
  {
@@ -76,13 +80,21 @@ module.exports = {
76
80
  }
77
81
  ],
78
82
  camelcase: 'off',
83
+ 'import/no-cycle': 'off',
84
+ 'import/no-named-as-default': 'warn',
79
85
  'no-shadow': 'off',
80
86
  'no-unused-expressions': 'off'
81
87
  },
82
88
  settings: {
89
+ 'import/parsers': {
90
+ '@typescript-eslint/parser': ['.ts', '.tsx']
91
+ },
83
92
  'import/resolver': {
84
93
  alias: {
85
94
  extensions: ['.ts', '.tsx', '.js', '.jsx']
95
+ },
96
+ typescript: {
97
+ alwaysTryTypes: true
86
98
  }
87
99
  }
88
100
  }
@@ -0,0 +1,48 @@
1
+ module.exports = {
2
+ extends: [ '../node/typescript.eslintrc.js'],
3
+ overrides: [
4
+ {
5
+ files: ["*.spec.js", "*.test.ts", "*.tests.ts"],
6
+ rules: {
7
+ "import/first": 0,
8
+ "import/order": 0,
9
+ "@typescript-eslint/ban-ts-comment": 0,
10
+ "@typescript-eslint/no-explicit-any": 0
11
+ }
12
+ }
13
+ ],
14
+ rules: {
15
+ "import/extensions": ["off"],
16
+ "no-console": "off",
17
+ "no-underscore-dangle": "off",
18
+ "class-methods-use-this": "off",
19
+ "@typescript-eslint/naming-convention": [
20
+ "error",
21
+ {
22
+ format: ["camelCase", "PascalCase", "UPPER_CASE"],
23
+ selector: "variable"
24
+ },
25
+ {
26
+ filter: {
27
+ match: false,
28
+ regex: "(__esModule|.+-.+)"
29
+ },
30
+ format: ["snake_case", "camelCase", "PascalCase", "UPPER_CASE"],
31
+ selector: "property",
32
+ leadingUnderscore: "allow"
33
+ },
34
+ {
35
+ filter: {
36
+ match: false,
37
+ regex: "^_$"
38
+ },
39
+ format: ["snake_case", "camelCase", "PascalCase"],
40
+ selector: "parameter"
41
+ }
42
+ ],
43
+ "@typescript-eslint/require-array-sort-compare": "error"
44
+ },
45
+ parserOptions: {
46
+ project: ["./tsconfig.json"]
47
+ }
48
+ }
package/jest/index.js CHANGED
@@ -1,12 +1,16 @@
1
1
  module.exports = {
2
2
  moduleNameMapper: {
3
3
  '\\.(s?css|png|svg|jpg)$': 'identity-obj-proxy',
4
+ '^.+\\.(css|styl|less|sass|scss|png|jpg|ttf|woff|woff2)$':
5
+ 'jest-transform-stub',
4
6
  '^react($|/.+)': '<rootDir>/node_modules/react$1'
5
7
  },
6
8
  setupFilesAfterEnv: ['@testing-library/jest-dom/extend-expect'],
7
9
  testEnvironment: 'jsdom',
8
- testPathIgnorePatterns: ['/node_modules/'],
10
+ testPathIgnorePatterns: ['/node_modules/', '!*.cypress.spec.tsx'],
9
11
  transform: {
12
+ '.+\\.(css|styl|less|sass|scss|png|jpg|ttf|woff|woff2)$':
13
+ 'jest-transform-stub',
10
14
  '^.+\\.[jt]sx?$': [
11
15
  '@swc/jest',
12
16
  {
@@ -0,0 +1,49 @@
1
+ /*
2
+ * Copyright 2023 Centreon Team
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+
17
+ // For a detailed explanation regarding each configuration property, visit:
18
+ // https://jestjs.io/docs/en/configuration.html
19
+ const path = require('path');
20
+
21
+ const rootPath = path.join(__dirname);
22
+
23
+
24
+
25
+ module.exports = {
26
+ rootDir: rootPath,
27
+ // Automatically clear mock calls and instances between every test
28
+ clearMocks: true,
29
+ // The directory where Jest should output its coverage files
30
+ coverageDirectory: '<rootDir>/coverage',
31
+ // An array of regexp pattern strings used to skip coverage collection
32
+ coveragePathIgnorePatterns: ['\\\\node_modules\\\\', 'tests'],
33
+
34
+ // An array of file extensions your modules use
35
+ moduleFileExtensions: ['ts', 'tsx', 'js', 'jsx'],
36
+
37
+ // Automatically reset mock state between every test
38
+ // resetMocks: true,
39
+
40
+ testMatch: ['**/*.(test|tests|spec|specs).+(ts|tsx|js)'],
41
+
42
+ // This option allows the use of a custom results processor
43
+ // testResultsProcessor: 'jest-sonar-reporter',
44
+
45
+ // A map from regular expressions to paths to transformers
46
+ transform: {
47
+ '^.+\\.(ts|tsx)$': ['ts-jest', { tsconfig: '<rootDir>/tsconfig.json' }],
48
+ },
49
+ };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@centreon/js-config",
3
3
  "description": "Centreon Frontend shared build configuration",
4
- "version": "24.4.12",
4
+ "version": "24.4.13",
5
5
  "repository": {
6
6
  "type": "git",
7
7
  "url": "git+https://github.com/centreon/centreon-frontend.git"
@@ -16,13 +16,12 @@
16
16
  "url": "https://github.com/centreon/centreon-frontend/issues"
17
17
  },
18
18
  "devDependencies": {
19
- "@badeball/cypress-cucumber-preprocessor": "^14.0.0",
20
- "@types/dockerode": "^3.3.16",
21
- "dockerode": "^3.3.5",
19
+ "@tsconfig/node16": "^16.1.1",
22
20
  "eslint": "^8.17.0",
23
21
  "eslint-config-airbnb": "19.0.4",
24
22
  "eslint-config-prettier": "^8.5.0",
25
23
  "eslint-import-resolver-alias": "^1.1.2",
24
+ "eslint-import-resolver-typescript": "^3.5.5",
26
25
  "eslint-plugin-babel": "^5.3.1",
27
26
  "eslint-plugin-hooks": "^0.4.3",
28
27
  "eslint-plugin-import": "^2.26.0",
@@ -43,5 +42,18 @@
43
42
  "tsconfig",
44
43
  "webpack",
45
44
  "cypress"
46
- ]
45
+ ],
46
+ "dependencies": {
47
+ "@badeball/cypress-cucumber-preprocessor": "^19.1.0",
48
+ "@bahmutov/cypress-esbuild-preprocessor": "^2.2.0",
49
+ "@esbuild-plugins/node-globals-polyfill": "^0.2.3",
50
+ "@esbuild-plugins/node-modules-polyfill": "^0.2.2",
51
+ "@types/cypress-cucumber-preprocessor": "^4.0.5",
52
+ "@types/dockerode": "^3.3.23",
53
+ "cypress-multi-reporters": "^1.6.4",
54
+ "cypress-terminal-report": "^5.3.9",
55
+ "dockerode": "^4.0.0",
56
+ "esbuild": "^0.19.5",
57
+ "mochawesome": "^7.1.3"
58
+ }
47
59
  }
@@ -1,13 +1,14 @@
1
1
  {
2
2
  "compilerOptions": {
3
- "moduleResolution": "node",
4
3
  "downlevelIteration": true,
5
- "module": "es6",
6
- "target": "es6",
4
+ "module": "ESNext",
5
+ "moduleResolution": "node",
6
+ "target": "es2018",
7
7
  "jsx": "react-jsx",
8
8
  "strict": true,
9
9
  "noImplicitAny": false,
10
10
  "skipLibCheck": true,
11
- "esModuleInterop": true
11
+ "esModuleInterop": true,
12
+ "resolveJsonModule": true
12
13
  }
13
14
  }
@@ -0,0 +1,14 @@
1
+ {
2
+ "extends": "@tsconfig/node16/tsconfig.json",
3
+ "compilerOptions": {
4
+ "sourceMap": true,
5
+ "allowJs": true,
6
+ "strictNullChecks": false,
7
+ "declaration": false,
8
+ "esModuleInterop": true,
9
+ "types": [
10
+ "@types/jest",
11
+ "node"
12
+ ]
13
+ }
14
+ }