|
@@ -2,6 +2,7 @@
|
|
|
|
|
|
describe('Certificates endpoints', () => {
|
|
|
let token;
|
|
|
+ let certID;
|
|
|
|
|
|
before(() => {
|
|
|
cy.getToken().then((tok) => {
|
|
@@ -24,6 +25,52 @@ describe('Certificates endpoints', () => {
|
|
|
});
|
|
|
});
|
|
|
|
|
|
+ it('Custom certificate lifecycle', function() {
|
|
|
+ cy.task('backendApiPost', {
|
|
|
+ token: token,
|
|
|
+ path: '/api/nginx/certificates',
|
|
|
+ data: {
|
|
|
+ provider: "other",
|
|
|
+ nice_name: "Test Certificate",
|
|
|
+ },
|
|
|
+ }).then((data) => {
|
|
|
+ cy.validateSwaggerSchema('post', 201, '/nginx/certificates', data);
|
|
|
+ expect(data).to.have.property('id');
|
|
|
+ certID = data.id;
|
|
|
+
|
|
|
+ cy.task('backendApiPostFiles', {
|
|
|
+ token: token,
|
|
|
+ path: `/api/nginx/certificates/${certID}/upload`,
|
|
|
+ files: {
|
|
|
+ certificate: 'test.example.com.pem',
|
|
|
+ certificate_key: 'test.example.com-key.pem',
|
|
|
+ },
|
|
|
+ }).then((data) => {
|
|
|
+ cy.validateSwaggerSchema('post', 201, '/nginx/certificates/upload', data);
|
|
|
+ expect(data).to.have.property('certificate');
|
|
|
+ expect(data).to.have.property('certificate_key');
|
|
|
+
|
|
|
+ cy.task('backendApiDelete', {
|
|
|
+ token: token,
|
|
|
+ path: `/api/nginx/certificates/${certID}`
|
|
|
+ }).then((data) => {
|
|
|
+ cy.validateSwaggerSchema('delete', 200, '/nginx/certificates/{certID}', data);
|
|
|
+ expect(data).to.be.equal(true);
|
|
|
+ });
|
|
|
+ });
|
|
|
+ });
|
|
|
+ });
|
|
|
+
|
|
|
+ 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() {
|
|
|
cy.task('backendApiPost', {
|
|
|
token: token,
|