1
0
mirror of https://github.com/Unleash/unleash.git synced 2024-12-22 19:07:54 +01:00
unleash.unleash/frontend/cypress/support/API.ts
Gastón Fournier 9f3648dc81
chore: test migration backward compatibility (#5492)
## About the changes
This PR will validate that our current migrations are backward
compatible with the latest stable release of Unleash.
It will do so by starting a database, applying the latest migrations,
and then starting a docker container with the last stable unleash
release and running UI tests against it.

There's a risk that the current version of UI tests will not work with
the previous version of our UI. Because of that we copied the previous
version of cypress tests
(https://github.com/Unleash/unleash/tree/5.6/frontend/cypress) into oss
folder and removed the ones that are enterprise only. We can discuss a
better way of doing this to avoid having to maintain this folder always
in sync with the previous version of Unleash

This action will only run when there are changes in migrations or to
cypress tests.
2023-11-30 18:20:13 +01:00

132 lines
3.5 KiB
TypeScript

///<reference path="../global.d.ts" />
import Chainable = Cypress.Chainable;
const baseUrl = Cypress.config().baseUrl;
const password = `${Cypress.env(`AUTH_PASSWORD`)}_A`;
const PROJECT_MEMBER = 5;
export const createFeature_API = (
featureName: string,
projectName?: string,
options?: Partial<Cypress.RequestOptions>,
): Chainable<any> => {
const project = projectName || 'default';
return cy.request({
url: `${baseUrl}/api/admin/projects/${project}/features`,
method: 'POST',
body: {
name: `${featureName}`,
description: 'hello-world',
type: 'release',
impressionData: false,
},
...options,
});
};
export const deleteFeature_API = (
name: string,
projectName?: string,
): Chainable<any> => {
const project = projectName || 'default';
cy.request({
method: 'DELETE',
url: `${baseUrl}/api/admin/projects/${project}/features/${name}`,
});
return cy.request({
method: 'DELETE',
url: `${baseUrl}/api/admin/archive/${name}`,
});
};
export const createProject_API = (
project: string,
options?: Partial<Cypress.RequestOptions>,
): Chainable<any> => {
return cy.request({
url: `${baseUrl}/api/admin/projects`,
method: 'POST',
body: {
id: project,
name: project,
description: project,
impressionData: false,
},
...options,
});
};
export const deleteProject_API = (name: string): Chainable<any> => {
return cy.request({
method: 'DELETE',
url: `${baseUrl}/api/admin/projects/${name}`,
});
};
export const createUser_API = (userName: string, role: number) => {
const name = `${userName}`;
const email = `${name}@test.com`;
const userIds: number[] = [];
const userCredentials: Cypress.UserCredentials[] = [];
cy.request('POST', `${baseUrl}/api/admin/user-admin`, {
name: name,
email: `${name}@test.com`,
username: `${name}@test.com`,
sendEmail: false,
rootRole: role,
})
.as(name)
.then((response) => {
const id = response.body.id;
updateUserPassword_API(id).then(() => {
addUserToProject_API(id, PROJECT_MEMBER).then((value) => {
userIds.push(id);
userCredentials.push({ email, password });
});
});
});
return cy.wrap({ userIds, userCredentials });
};
export const updateUserPassword_API = (id: number, pass?: string): Chainable =>
cy.request(
'POST',
`${baseUrl}/api/admin/user-admin/${id}/change-password`,
{
password: pass || password,
},
);
export const addUserToProject_API = (
id: number,
role: number,
projectName?: string,
): Chainable => {
const project = projectName || 'default';
return cy.request(
'POST',
`${baseUrl}/api/admin/projects/${project}/role/${role}/access`,
{
groups: [],
users: [{ id }],
},
);
};
interface IEnvironment {
name: string;
type: 'development' | 'preproduction' | 'test' | 'production';
}
export const createEnvironment_API = (
environment: IEnvironment,
options?: Partial<Cypress.RequestOptions>,
): Chainable<any> => {
return cy.request({
url: `${baseUrl}/api/admin/environments`,
method: 'POST',
body: environment,
...options,
});
};