mirror of
https://github.com/zoriya/flood.git
synced 2025-12-05 23:06:20 +00:00
client: initial integration tests
This commit is contained in:
@@ -4,3 +4,4 @@
|
|||||||
**/*.d.ts
|
**/*.d.ts
|
||||||
/docs
|
/docs
|
||||||
coverage/
|
coverage/
|
||||||
|
cypress/
|
||||||
|
|||||||
2
.github/workflows/build.yml
vendored
2
.github/workflows/build.yml
vendored
@@ -23,6 +23,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
node-version: ${{ matrix.node }}
|
node-version: ${{ matrix.node }}
|
||||||
|
|
||||||
- run: npm ci
|
- run: npm ci --no-optional
|
||||||
- run: npm run build
|
- run: npm run build
|
||||||
- run: npm run start -- --help
|
- run: npm run start -- --help
|
||||||
|
|||||||
2
.github/workflows/check.yml
vendored
2
.github/workflows/check.yml
vendored
@@ -24,5 +24,5 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
node-version: ${{ matrix.node }}
|
node-version: ${{ matrix.node }}
|
||||||
|
|
||||||
- run: npm ci
|
- run: npm ci --no-optional
|
||||||
- run: npm run ${{ matrix.check }}
|
- run: npm run ${{ matrix.check }}
|
||||||
|
|||||||
2
.github/workflows/publish-rolling.yml
vendored
2
.github/workflows/publish-rolling.yml
vendored
@@ -22,7 +22,7 @@ jobs:
|
|||||||
node-version: ${{ matrix.node }}
|
node-version: ${{ matrix.node }}
|
||||||
registry-url: 'https://registry.npmjs.org'
|
registry-url: 'https://registry.npmjs.org'
|
||||||
|
|
||||||
- run: npm ci
|
- run: npm ci --no-optional
|
||||||
|
|
||||||
- name: Tag rolling release
|
- name: Tag rolling release
|
||||||
run: |
|
run: |
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
name: Test
|
name: Test backend
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
@@ -7,7 +7,7 @@ on:
|
|||||||
pull_request:
|
pull_request:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
test:
|
test-backend:
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
|
|
||||||
strategy:
|
strategy:
|
||||||
@@ -25,7 +25,7 @@ jobs:
|
|||||||
|
|
||||||
- run: sudo apt-get install -y rtorrent
|
- run: sudo apt-get install -y rtorrent
|
||||||
|
|
||||||
- run: npm ci
|
- run: npm ci --no-optional
|
||||||
- run: npm run build
|
- run: npm run build
|
||||||
- run: npm run start -- --help
|
- run: npm run start -- --help
|
||||||
- run: npm test
|
- run: npm test
|
||||||
35
.github/workflows/test-frontend.yml
vendored
Normal file
35
.github/workflows/test-frontend.yml
vendored
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
name: Test frontend
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches-ignore:
|
||||||
|
- 'integration/**'
|
||||||
|
pull_request:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test-frontend:
|
||||||
|
runs-on: ubuntu-16.04
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- name: Use Node.js 14
|
||||||
|
uses: actions/setup-node@v1
|
||||||
|
with:
|
||||||
|
node-version: 14
|
||||||
|
|
||||||
|
- run: sudo apt-get install -y rtorrent
|
||||||
|
|
||||||
|
- run: sudo npm i -g wait-on
|
||||||
|
- run: npm ci
|
||||||
|
- run: npm run build
|
||||||
|
|
||||||
|
- run: npm run start -- -p 4200 &
|
||||||
|
- run: wait-on tcp:4200
|
||||||
|
|
||||||
|
- uses: cypress-io/github-action@v2
|
||||||
|
with:
|
||||||
|
record: true
|
||||||
|
env:
|
||||||
|
CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }}
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
4
.gitignore
vendored
4
.gitignore
vendored
@@ -62,3 +62,7 @@ out/
|
|||||||
|
|
||||||
# Coverage reports
|
# Coverage reports
|
||||||
coverage/
|
coverage/
|
||||||
|
|
||||||
|
# Test results
|
||||||
|
cypress/videos
|
||||||
|
cypress/screenshots
|
||||||
|
|||||||
3
cypress.json
Normal file
3
cypress.json
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"projectId": "akrovg"
|
||||||
|
}
|
||||||
83
cypress/integration/register.spec.ts
Normal file
83
cypress/integration/register.spec.ts
Normal file
@@ -0,0 +1,83 @@
|
|||||||
|
context('Register', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.visit('http://127.0.0.1:4200/register');
|
||||||
|
cy.url().should('include', 'register');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('Client selection menu', () => {
|
||||||
|
cy.get('.select').click();
|
||||||
|
cy.get('.context-menu').should('be.visible');
|
||||||
|
cy.get('.select__item').contains('rTorrent').click();
|
||||||
|
cy.get('.context-menu').should('not.be.visible');
|
||||||
|
cy.get('.input[name="client"]').should('have.value', 'rTorrent');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('Connection type selection', () => {
|
||||||
|
cy.get('.toggle-input__label').contains('TCP').click();
|
||||||
|
cy.get('.toggle-input__element[value="tcp"]').should('be.checked');
|
||||||
|
cy.get('.toggle-input__element[value="socket"]').should('not.be.checked');
|
||||||
|
cy.get('.input--text[name="host"]').should('be.visible');
|
||||||
|
cy.get('.input--text[name="port"]').should('be.visible');
|
||||||
|
cy.get('.input--text[name="socket"]').should('not.be.visible');
|
||||||
|
|
||||||
|
cy.get('.toggle-input__label').contains('Socket').click();
|
||||||
|
cy.get('.toggle-input__element[value="tcp"]').should('not.be.checked');
|
||||||
|
cy.get('.toggle-input__element[value="socket"]').should('be.checked');
|
||||||
|
cy.get('.input--text[name="host"]').should('not.be.visible');
|
||||||
|
cy.get('.input--text[name="port"]').should('not.be.visible');
|
||||||
|
cy.get('.input--text[name="socket"]').should('be.visible');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('Register without username', () => {
|
||||||
|
cy.get('.input[name="password"]').type('test');
|
||||||
|
cy.get('.select').click();
|
||||||
|
cy.get('.select__item').contains('rTorrent').click();
|
||||||
|
cy.get('.toggle-input__label').contains('Socket').click();
|
||||||
|
cy.get('.input--text[name="socket"]').type('/data/rtorrent.sock');
|
||||||
|
cy.get('.button[type="submit"]').click();
|
||||||
|
cy.get('.application__view--auth-form').should('be.visible');
|
||||||
|
cy.get('.application__content').should('not.be.visible');
|
||||||
|
cy.get('.application__loading-overlay').should('not.be.visible');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('Register without password', () => {
|
||||||
|
cy.get('.input[name="username"]').type('test');
|
||||||
|
cy.get('.select').click();
|
||||||
|
cy.get('.select__item').contains('rTorrent').click();
|
||||||
|
cy.get('.toggle-input__label').contains('TCP').click();
|
||||||
|
cy.get('.input--text[name="host"]').type('127.0.0.1');
|
||||||
|
cy.get('.input--text[name="port"]').type('5000');
|
||||||
|
cy.get('.button[type="submit"]').click();
|
||||||
|
cy.get('.application__view--auth-form').should('be.visible');
|
||||||
|
cy.get('.application__content').should('not.be.visible');
|
||||||
|
cy.get('.application__loading-overlay').should('not.be.visible');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('Register without connection settings', () => {
|
||||||
|
cy.get('.input[name="username"]').type('test');
|
||||||
|
cy.get('.input[name="password"]').type('test');
|
||||||
|
cy.get('.button[type="submit"]').click();
|
||||||
|
cy.get('.application__view--auth-form').should('be.visible');
|
||||||
|
cy.get('.application__content').should('not.be.visible');
|
||||||
|
cy.get('.application__loading-overlay').should('not.be.visible');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('Register with socket connection settings', () => {
|
||||||
|
cy.get('.input[name="username"]').type('test');
|
||||||
|
cy.get('.input[name="password"]').type('test');
|
||||||
|
cy.get('.select').click();
|
||||||
|
cy.get('.select__item').contains('rTorrent').click();
|
||||||
|
cy.get('.toggle-input__label').contains('Socket').click();
|
||||||
|
cy.get('.input--text[name="socket"]').type('/data/rtorrent.sock');
|
||||||
|
|
||||||
|
cy.server();
|
||||||
|
cy.route({method: 'POST', url: 'http://127.0.0.1:4200/api/auth/register', response: {}, status: 403}).as(
|
||||||
|
'register-request',
|
||||||
|
);
|
||||||
|
|
||||||
|
cy.get('.button[type="submit"]').click();
|
||||||
|
|
||||||
|
cy.get('.application__view--auth-form').should('not.be.visible');
|
||||||
|
cy.get('.application__content').should('be.visible');
|
||||||
|
});
|
||||||
|
});
|
||||||
21
cypress/plugins/index.js
Normal file
21
cypress/plugins/index.js
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
/// <reference types="cypress" />
|
||||||
|
// ***********************************************************
|
||||||
|
// This example plugins/index.js can be used to load plugins
|
||||||
|
//
|
||||||
|
// You can change the location of this file or turn off loading
|
||||||
|
// the plugins file with the 'pluginsFile' configuration option.
|
||||||
|
//
|
||||||
|
// You can read more here:
|
||||||
|
// https://on.cypress.io/plugins-guide
|
||||||
|
// ***********************************************************
|
||||||
|
|
||||||
|
// This function is called when a project is opened or re-opened (e.g. due to
|
||||||
|
// the project's config changing)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {Cypress.PluginConfig}
|
||||||
|
*/
|
||||||
|
module.exports = (on, config) => {
|
||||||
|
// `on` is used to hook into various events Cypress emits
|
||||||
|
// `config` is the resolved Cypress config
|
||||||
|
};
|
||||||
25
cypress/support/commands.js
Normal file
25
cypress/support/commands.js
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
// ***********************************************
|
||||||
|
// 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) => { ... })
|
||||||
20
cypress/support/index.js
Normal file
20
cypress/support/index.js
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
// ***********************************************************
|
||||||
|
// 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
|
||||||
|
// ***********************************************************
|
||||||
|
|
||||||
|
// Import commands.js using ES2015 syntax:
|
||||||
|
import './commands';
|
||||||
|
|
||||||
|
// Alternatively you can use CommonJS syntax:
|
||||||
|
// require('./commands')
|
||||||
9
cypress/tsconfig.json
Normal file
9
cypress/tsconfig.json
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
{
|
||||||
|
"compilerOptions": {
|
||||||
|
"target": "es5",
|
||||||
|
"lib": ["es5", "dom"],
|
||||||
|
"types": ["cypress"]
|
||||||
|
},
|
||||||
|
"include": ["**/*.ts"],
|
||||||
|
"resolveJsonModule": true
|
||||||
|
}
|
||||||
1365
package-lock.json
generated
1365
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@@ -33,7 +33,8 @@
|
|||||||
"start:production": "UPDATED_SCRIPT=start npm run deprecated-warning && npm start",
|
"start:production": "UPDATED_SCRIPT=start npm run deprecated-warning && npm start",
|
||||||
"start:watch": "UPDATED_SCRIPT=start:development:client npm run deprecated-warning && npm run start:development:client",
|
"start:watch": "UPDATED_SCRIPT=start:development:client npm run deprecated-warning && npm run start:development:client",
|
||||||
"test": "jest --forceExit",
|
"test": "jest --forceExit",
|
||||||
"test:watch": "jest --watchAll --forceExit"
|
"test:watch": "jest --watchAll --forceExit",
|
||||||
|
"test:client": "FLOOD_OPTION_port=4200 start-server-and-test start 4200 'cypress run'"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"argon2-browser": "^1.15.2",
|
"argon2-browser": "^1.15.2",
|
||||||
@@ -186,6 +187,10 @@
|
|||||||
"yargs": "^16.0.3",
|
"yargs": "^16.0.3",
|
||||||
"zod": "^1.11.9"
|
"zod": "^1.11.9"
|
||||||
},
|
},
|
||||||
|
"optionalDependencies": {
|
||||||
|
"cypress": "^5.4.0",
|
||||||
|
"start-server-and-test": "^1.11.5"
|
||||||
|
},
|
||||||
"eslintConfig": {
|
"eslintConfig": {
|
||||||
"extends": "react-app"
|
"extends": "react-app"
|
||||||
},
|
},
|
||||||
|
|||||||
Reference in New Issue
Block a user