From 863258f23d4756ec99ddb248bec3a9e66f8fce8f Mon Sep 17 00:00:00 2001 From: Frank Strieter Date: Tue, 22 Mar 2022 14:24:00 +0100 Subject: [PATCH] chore: replace protractor with cypress --- src-ui/cypress.json | 9 +++++++ src-ui/cypress/integration/spec.ts | 7 +++++ src-ui/cypress/plugins/index.ts | 3 +++ src-ui/cypress/support/commands.ts | 43 ++++++++++++++++++++++++++++++ src-ui/cypress/support/index.ts | 17 ++++++++++++ src-ui/cypress/tsconfig.json | 8 ++++++ 6 files changed, 87 insertions(+) create mode 100644 src-ui/cypress.json create mode 100644 src-ui/cypress/integration/spec.ts create mode 100644 src-ui/cypress/plugins/index.ts create mode 100644 src-ui/cypress/support/commands.ts create mode 100644 src-ui/cypress/support/index.ts create mode 100644 src-ui/cypress/tsconfig.json diff --git a/src-ui/cypress.json b/src-ui/cypress.json new file mode 100644 index 000000000..bd321dcbf --- /dev/null +++ b/src-ui/cypress.json @@ -0,0 +1,9 @@ +{ + "integrationFolder": "cypress/integration", + "supportFile": "cypress/support/index.ts", + "videosFolder": "cypress/videos", + "screenshotsFolder": "cypress/screenshots", + "pluginsFile": "cypress/plugins/index.ts", + "fixturesFolder": "cypress/fixtures", + "baseUrl": "http://localhost:4200" +} \ No newline at end of file diff --git a/src-ui/cypress/integration/spec.ts b/src-ui/cypress/integration/spec.ts new file mode 100644 index 000000000..6b0753a8a --- /dev/null +++ b/src-ui/cypress/integration/spec.ts @@ -0,0 +1,7 @@ +describe('My First Test', () => { + it('Visits the initial project page', () => { + cy.visit('/') + cy.contains('Welcome') + cy.contains('sandbox app is running!') + }) +}) diff --git a/src-ui/cypress/plugins/index.ts b/src-ui/cypress/plugins/index.ts new file mode 100644 index 000000000..bfc9d3b65 --- /dev/null +++ b/src-ui/cypress/plugins/index.ts @@ -0,0 +1,3 @@ +// Plugins enable you to tap into, modify, or extend the internal behavior of Cypress +// For more info, visit https://on.cypress.io/plugins-api +module.exports = (on, config) => {} diff --git a/src-ui/cypress/support/commands.ts b/src-ui/cypress/support/commands.ts new file mode 100644 index 000000000..af1f44a0f --- /dev/null +++ b/src-ui/cypress/support/commands.ts @@ -0,0 +1,43 @@ +// *********************************************** +// This example namespace declaration will help +// with Intellisense and code completion in your +// IDE or Text Editor. +// *********************************************** +// declare namespace Cypress { +// interface Chainable { +// customCommand(param: any): typeof customCommand; +// } +// } +// +// function customCommand(param: any): void { +// console.warn(param); +// } +// +// NOTE: You can use it like so: +// Cypress.Commands.add('customCommand', customCommand); +// +// *********************************************** +// This example commands.js 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) => { ... }) diff --git a/src-ui/cypress/support/index.ts b/src-ui/cypress/support/index.ts new file mode 100644 index 000000000..ac293b616 --- /dev/null +++ b/src-ui/cypress/support/index.ts @@ -0,0 +1,17 @@ +// *********************************************************** +// This example support/index.js is processed and +// loaded automatically before your test files. +// +// This is a great place to put global configuration and +// behavior that modifies Cypress. +// +// You can change the location of this file or turn off +// automatically serving support files with the +// 'supportFile' configuration option. +// +// You can read more here: +// https://on.cypress.io/configuration +// *********************************************************** + +// When a command from ./commands is ready to use, import with `import './commands'` syntax +// import './commands'; diff --git a/src-ui/cypress/tsconfig.json b/src-ui/cypress/tsconfig.json new file mode 100644 index 000000000..79d78d7ec --- /dev/null +++ b/src-ui/cypress/tsconfig.json @@ -0,0 +1,8 @@ +{ + "extends": "../tsconfig.json", + "include": ["**/*.ts"], + "compilerOptions": { + "sourceMap": false, + "types": ["cypress"] + } +}