mirror of
https://github.com/xiaoxinpro/nginx-proxy-manager-zh.git
synced 2025-01-22 12:58:13 -05:00
Updated swagger cypress package,
which works with proxies
This commit is contained in:
parent
351ba8dacd
commit
f48e1b46a8
10
Jenkinsfile
vendored
10
Jenkinsfile
vendored
@ -127,6 +127,11 @@ pipeline {
|
|||||||
junit 'test/results/junit/*'
|
junit 'test/results/junit/*'
|
||||||
sh 'docker-compose down --remove-orphans --volumes -t 30 || true'
|
sh 'docker-compose down --remove-orphans --volumes -t 30 || true'
|
||||||
}
|
}
|
||||||
|
unstable {
|
||||||
|
dir(path: 'testing/results') {
|
||||||
|
archiveArtifacts(allowEmptyArchive: true, artifacts: '**/*', excludes: '**/*.xml')
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage('Test Mysql') {
|
stage('Test Mysql') {
|
||||||
@ -155,6 +160,11 @@ pipeline {
|
|||||||
junit 'test/results/junit/*'
|
junit 'test/results/junit/*'
|
||||||
sh 'docker-compose down --remove-orphans --volumes -t 30 || true'
|
sh 'docker-compose down --remove-orphans --volumes -t 30 || true'
|
||||||
}
|
}
|
||||||
|
unstable {
|
||||||
|
dir(path: 'testing/results') {
|
||||||
|
archiveArtifacts(allowEmptyArchive: true, artifacts: '**/*', excludes: '**/*.xml')
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage('MultiArch Build') {
|
stage('MultiArch Build') {
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# WARNING: This is a DEVELOPMENT docker-compose file, it should not be used for production.
|
# WARNING: This is a DEVELOPMENT docker-compose file, it should not be used for production.
|
||||||
services:
|
services:
|
||||||
|
|
||||||
npm:
|
fullstack:
|
||||||
image: nginxproxymanager:dev
|
image: nginxproxymanager:dev
|
||||||
container_name: npm_core
|
container_name: npm_core
|
||||||
build:
|
build:
|
||||||
@ -67,7 +67,7 @@ services:
|
|||||||
URL: "http://npm:81/api/schema"
|
URL: "http://npm:81/api/schema"
|
||||||
PORT: '80'
|
PORT: '80'
|
||||||
depends_on:
|
depends_on:
|
||||||
- npm
|
- fullstack
|
||||||
|
|
||||||
squid:
|
squid:
|
||||||
image: ubuntu/squid
|
image: ubuntu/squid
|
||||||
|
@ -15,7 +15,7 @@ module.exports = defineConfig({
|
|||||||
return require("../plugins/index.js")(on, config);
|
return require("../plugins/index.js")(on, config);
|
||||||
},
|
},
|
||||||
env: {
|
env: {
|
||||||
swaggerBase: 'http://fullstack:81/api/schema',
|
swaggerBase: '{{baseUrl}}/api/schema?ts=' + Date.now(),
|
||||||
},
|
},
|
||||||
baseUrl: 'http://fullstack:81',
|
baseUrl: 'http://fullstack:81',
|
||||||
}
|
}
|
||||||
|
@ -1,22 +0,0 @@
|
|||||||
const { defineConfig } = require('cypress');
|
|
||||||
|
|
||||||
module.exports = defineConfig({
|
|
||||||
requestTimeout: 30000,
|
|
||||||
defaultCommandTimeout: 20000,
|
|
||||||
reporter: 'cypress-multi-reporters',
|
|
||||||
reporterOptions: {
|
|
||||||
configFile: 'multi-reporter.json'
|
|
||||||
},
|
|
||||||
video: false,
|
|
||||||
videosFolder: 'results/videos',
|
|
||||||
screenshotsFolder: 'results/screenshots',
|
|
||||||
e2e: {
|
|
||||||
setupNodeEvents(on, config) {
|
|
||||||
return require("../plugins/index.js")(on, config);
|
|
||||||
},
|
|
||||||
env: {
|
|
||||||
swaggerBase: 'http://npm:81/api/schema',
|
|
||||||
},
|
|
||||||
baseUrl: 'http://npm:81',
|
|
||||||
}
|
|
||||||
});
|
|
@ -1,4 +1,4 @@
|
|||||||
/// <reference types="Cypress" />
|
/// <reference types="cypress" />
|
||||||
|
|
||||||
describe('Certificates endpoints', () => {
|
describe('Certificates endpoints', () => {
|
||||||
let token;
|
let token;
|
||||||
@ -26,6 +26,7 @@ describe('Certificates endpoints', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it('Custom certificate lifecycle', function() {
|
it('Custom certificate lifecycle', function() {
|
||||||
|
// Create custom cert
|
||||||
cy.task('backendApiPost', {
|
cy.task('backendApiPost', {
|
||||||
token: token,
|
token: token,
|
||||||
path: '/api/nginx/certificates',
|
path: '/api/nginx/certificates',
|
||||||
@ -38,6 +39,7 @@ describe('Certificates endpoints', () => {
|
|||||||
expect(data).to.have.property('id');
|
expect(data).to.have.property('id');
|
||||||
certID = data.id;
|
certID = data.id;
|
||||||
|
|
||||||
|
// Upload files
|
||||||
cy.task('backendApiPostFiles', {
|
cy.task('backendApiPostFiles', {
|
||||||
token: token,
|
token: token,
|
||||||
path: `/api/nginx/certificates/${certID}/upload`,
|
path: `/api/nginx/certificates/${certID}/upload`,
|
||||||
@ -46,10 +48,19 @@ describe('Certificates endpoints', () => {
|
|||||||
certificate_key: 'test.example.com-key.pem',
|
certificate_key: 'test.example.com-key.pem',
|
||||||
},
|
},
|
||||||
}).then((data) => {
|
}).then((data) => {
|
||||||
cy.validateSwaggerSchema('post', 201, '/nginx/certificates/upload', data);
|
cy.validateSwaggerSchema('post', 200, '/nginx/certificates/{certID}/upload', data);
|
||||||
expect(data).to.have.property('certificate');
|
expect(data).to.have.property('certificate');
|
||||||
expect(data).to.have.property('certificate_key');
|
expect(data).to.have.property('certificate_key');
|
||||||
|
|
||||||
|
// Get all certs
|
||||||
|
cy.task('backendApiGet', {
|
||||||
|
token: token,
|
||||||
|
path: '/api/nginx/certificates?expand=owner'
|
||||||
|
}).then((data) => {
|
||||||
|
cy.validateSwaggerSchema('get', 200, '/nginx/certificates', data);
|
||||||
|
expect(data.length).to.be.greaterThan(0);
|
||||||
|
|
||||||
|
// Delete cert
|
||||||
cy.task('backendApiDelete', {
|
cy.task('backendApiDelete', {
|
||||||
token: token,
|
token: token,
|
||||||
path: `/api/nginx/certificates/${certID}`
|
path: `/api/nginx/certificates/${certID}`
|
||||||
@ -60,15 +71,6 @@ describe('Certificates endpoints', () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('Should be able to get all certs', function() {
|
|
||||||
cy.task('backendApiGet', {
|
|
||||||
token: token,
|
|
||||||
path: '/api/nginx/certificates?expand=owner'
|
|
||||||
}).then((data) => {
|
|
||||||
cy.validateSwaggerSchema('get', 200, '/nginx/certificates', data);
|
|
||||||
expect(data.length).to.be.greaterThan(0);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it('Request Certificate - CVE-2024-46256/CVE-2024-46257', function() {
|
it('Request Certificate - CVE-2024-46256/CVE-2024-46257', function() {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/// <reference types="Cypress" />
|
/// <reference types="cypress" />
|
||||||
|
|
||||||
describe('Basic API checks', () => {
|
describe('Basic API checks', () => {
|
||||||
it('Should return a valid health payload', function () {
|
it('Should return a valid health payload', function () {
|
||||||
@ -12,7 +12,7 @@ describe('Basic API checks', () => {
|
|||||||
|
|
||||||
it('Should return a valid schema payload', function () {
|
it('Should return a valid schema payload', function () {
|
||||||
cy.task('backendApiGet', {
|
cy.task('backendApiGet', {
|
||||||
path: '/api/schema',
|
path: '/api/schema?ts=' + Date.now(),
|
||||||
}).then((data) => {
|
}).then((data) => {
|
||||||
expect(data.openapi).to.be.equal('3.1.0');
|
expect(data.openapi).to.be.equal('3.1.0');
|
||||||
});
|
});
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/// <reference types="Cypress" />
|
/// <reference types="cypress" />
|
||||||
|
|
||||||
describe('Hosts endpoints', () => {
|
describe('Hosts endpoints', () => {
|
||||||
let token;
|
let token;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/// <reference types="Cypress" />
|
/// <reference types="cypress" />
|
||||||
|
|
||||||
describe('Users endpoints', () => {
|
describe('Users endpoints', () => {
|
||||||
let token;
|
let token;
|
||||||
|
@ -80,7 +80,7 @@ BackendApi.prototype._handleError = function(err, resolve, reject, returnOnError
|
|||||||
* @returns {Promise<object>}
|
* @returns {Promise<object>}
|
||||||
*/
|
*/
|
||||||
BackendApi.prototype.request = function (method, path, returnOnError, data) {
|
BackendApi.prototype.request = function (method, path, returnOnError, data) {
|
||||||
logger(method.toUpperCase(), this.config.baseUrl + path);
|
logger(method.toUpperCase(), path);
|
||||||
const options = this._prepareOptions(returnOnError);
|
const options = this._prepareOptions(returnOnError);
|
||||||
|
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
const {SwaggerValidation} = require('@jc21/cypress-swagger-validation');
|
const { SwaggerValidation } = require('@jc21/cypress-swagger-validation');
|
||||||
|
|
||||||
module.exports = (on, config) => {
|
module.exports = (on, config) => {
|
||||||
// Replace swaggerBase config var wildcard
|
// Replace swaggerBase config var wildcard
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
"description": "",
|
"description": "",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@jc21/cypress-swagger-validation": "^0.2.8",
|
"@jc21/cypress-swagger-validation": "^0.3.1",
|
||||||
"axios": "^1.7.7",
|
"axios": "^1.7.7",
|
||||||
"cypress": "^13.15.0",
|
"cypress": "^13.15.0",
|
||||||
"cypress-multi-reporters": "^1.6.4",
|
"cypress-multi-reporters": "^1.6.4",
|
||||||
@ -19,8 +19,8 @@
|
|||||||
"mocha-junit-reporter": "^2.2.1"
|
"mocha-junit-reporter": "^2.2.1"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"cypress": "HTTP_PROXY=127.0.0.1:8128 HTTPS_PROXY=127.0.0.1:8128 cypress open --config-file=cypress/config/dev.js",
|
"cypress": "HTTP_PROXY=127.0.0.1:8128 HTTPS_PROXY=127.0.0.1:8128 cypress open --config-file=cypress/config/ci.js",
|
||||||
"cypress:headless": "HTTP_PROXY=127.0.0.1:8128 HTTPS_PROXY=127.0.0.1:8128 cypress run --config-file=cypress/config/dev.js"
|
"cypress:headless": "HTTP_PROXY=127.0.0.1:8128 HTTPS_PROXY=127.0.0.1:8128 cypress run --config-file=cypress/config/ci.js"
|
||||||
},
|
},
|
||||||
"author": "",
|
"author": "",
|
||||||
"license": "ISC"
|
"license": "ISC"
|
||||||
|
@ -11,14 +11,13 @@
|
|||||||
call-me-maybe "^1.0.1"
|
call-me-maybe "^1.0.1"
|
||||||
js-yaml "^3.13.1"
|
js-yaml "^3.13.1"
|
||||||
|
|
||||||
"@apidevtools/json-schema-ref-parser@9.0.9":
|
"@apidevtools/json-schema-ref-parser@^11.7.2":
|
||||||
version "9.0.9"
|
version "11.7.2"
|
||||||
resolved "https://registry.yarnpkg.com/@apidevtools/json-schema-ref-parser/-/json-schema-ref-parser-9.0.9.tgz#d720f9256e3609621280584f2b47ae165359268b"
|
resolved "https://registry.yarnpkg.com/@apidevtools/json-schema-ref-parser/-/json-schema-ref-parser-11.7.2.tgz#cdf3e0aded21492364a70e193b45b7cf4177f031"
|
||||||
integrity sha512-GBD2Le9w2+lVFoc4vswGI/TjkNIZSVp7+9xPf+X3uidBfWnAeUWmquteSyt0+VCrhNMWj/FTABISQrD3Z/YA+w==
|
integrity sha512-4gY54eEGEstClvEkGnwVkTkrx0sqwemEFG5OSRRn3tD91XH0+Q8XIkYIfo7IwEWPpJZwILb9GUXeShtplRc/eA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jsdevtools/ono" "^7.1.3"
|
"@jsdevtools/ono" "^7.1.3"
|
||||||
"@types/json-schema" "^7.0.6"
|
"@types/json-schema" "^7.0.15"
|
||||||
call-me-maybe "^1.0.1"
|
|
||||||
js-yaml "^4.1.0"
|
js-yaml "^4.1.0"
|
||||||
|
|
||||||
"@apidevtools/openapi-schemas@^2.1.0":
|
"@apidevtools/openapi-schemas@^2.1.0":
|
||||||
@ -167,15 +166,16 @@
|
|||||||
resolved "https://registry.yarnpkg.com/@humanwhocodes/retry/-/retry-0.3.1.tgz#c72a5c76a9fbaf3488e231b13dc52c0da7bab42a"
|
resolved "https://registry.yarnpkg.com/@humanwhocodes/retry/-/retry-0.3.1.tgz#c72a5c76a9fbaf3488e231b13dc52c0da7bab42a"
|
||||||
integrity sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==
|
integrity sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==
|
||||||
|
|
||||||
"@jc21/cypress-swagger-validation@^0.2.8":
|
"@jc21/cypress-swagger-validation@^0.3.1":
|
||||||
version "0.2.8"
|
version "0.3.1"
|
||||||
resolved "https://registry.yarnpkg.com/@jc21/cypress-swagger-validation/-/cypress-swagger-validation-0.2.8.tgz#8ab059bd41e3ee100a1998a1484b9e5a2e9a4224"
|
resolved "https://registry.yarnpkg.com/@jc21/cypress-swagger-validation/-/cypress-swagger-validation-0.3.1.tgz#1cdd49850a20f876ed62149623f99988264751be"
|
||||||
integrity sha512-9fiZIHj3//bJjC5YUMOc42RnoEUeeokVn6xtMnP52XIZ/ryWQ9PIyFdlOAH8q/LW/uPxozJo2+hdB6ou4iurag==
|
integrity sha512-Vdt1gLfj8p0tJhA42Cfn43XBbsKocNfVCEVSwkn7RmZgWUyRKjqhBBRTVa9cKZTozyg8Co/yhBMsNyjmHFVXtQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
|
"@apidevtools/json-schema-ref-parser" "^11.7.2"
|
||||||
"@apidevtools/swagger-parser" "^10.1.0"
|
"@apidevtools/swagger-parser" "^10.1.0"
|
||||||
ajv "^8.17.1"
|
ajv "^8.17.1"
|
||||||
|
axios "^1.7.7"
|
||||||
json-schema "^0.4.0"
|
json-schema "^0.4.0"
|
||||||
json-schema-ref-parser "^9.0.9"
|
|
||||||
jsonpath "^1.1.1"
|
jsonpath "^1.1.1"
|
||||||
lodash "^4.17.21"
|
lodash "^4.17.21"
|
||||||
openapi-types "^12.1.3"
|
openapi-types "^12.1.3"
|
||||||
@ -196,7 +196,7 @@
|
|||||||
resolved "https://registry.yarnpkg.com/@types/estree/-/estree-1.0.6.tgz#628effeeae2064a1b4e79f78e81d87b7e5fc7b50"
|
resolved "https://registry.yarnpkg.com/@types/estree/-/estree-1.0.6.tgz#628effeeae2064a1b4e79f78e81d87b7e5fc7b50"
|
||||||
integrity sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==
|
integrity sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==
|
||||||
|
|
||||||
"@types/json-schema@^7.0.15", "@types/json-schema@^7.0.6":
|
"@types/json-schema@^7.0.15":
|
||||||
version "7.0.15"
|
version "7.0.15"
|
||||||
resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.15.tgz#596a1747233694d50f6ad8a7869fcb6f56cf5841"
|
resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.15.tgz#596a1747233694d50f6ad8a7869fcb6f56cf5841"
|
||||||
integrity sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==
|
integrity sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==
|
||||||
@ -1468,13 +1468,6 @@ json-buffer@3.0.1:
|
|||||||
resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13"
|
resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13"
|
||||||
integrity sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==
|
integrity sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==
|
||||||
|
|
||||||
json-schema-ref-parser@^9.0.9:
|
|
||||||
version "9.0.9"
|
|
||||||
resolved "https://registry.yarnpkg.com/json-schema-ref-parser/-/json-schema-ref-parser-9.0.9.tgz#66ea538e7450b12af342fa3d5b8458bc1e1e013f"
|
|
||||||
integrity sha512-qcP2lmGy+JUoQJ4DOQeLaZDqH9qSkeGCK3suKWxJXS82dg728Mn3j97azDMaOUmJAN4uCq91LdPx4K7E8F1a7Q==
|
|
||||||
dependencies:
|
|
||||||
"@apidevtools/json-schema-ref-parser" "9.0.9"
|
|
||||||
|
|
||||||
json-schema-traverse@^0.4.1:
|
json-schema-traverse@^0.4.1:
|
||||||
version "0.4.1"
|
version "0.4.1"
|
||||||
resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660"
|
resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660"
|
||||||
|
Loading…
Reference in New Issue
Block a user