2020-12-22 13:10:20 +01:00
|
|
|
const protectedPackageMetadata = require('./partials/pkg-protected');
|
|
|
|
const scopedPackageMetadata = require('./partials/pkg-scoped');
|
|
|
|
|
|
|
|
describe('/ (Verdaccio Page)', () => {
|
|
|
|
let page;
|
|
|
|
// this might be increased based on the delays included in all test
|
|
|
|
jest.setTimeout(20000);
|
|
|
|
|
|
|
|
const clickElement = async function (selector, options = { delay: 100 }) {
|
|
|
|
const button = await page.$(selector);
|
|
|
|
await button.focus();
|
|
|
|
await button.click(options);
|
|
|
|
};
|
|
|
|
|
|
|
|
const evaluateSignIn = async function (matchText = 'Login') {
|
|
|
|
const text = await page.evaluate(() => {
|
|
|
|
return document.querySelector('button[data-testid="header--button-login"]').textContent;
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(text).toMatch(matchText);
|
|
|
|
};
|
|
|
|
|
|
|
|
const getPackages = async function () {
|
|
|
|
return await page.$$('.package-title');
|
|
|
|
};
|
|
|
|
|
|
|
|
const logIn = async function () {
|
|
|
|
await clickElement('button[data-testid="header--button-login"]');
|
|
|
|
// we fill the sign in form
|
|
|
|
const signInDialog = await page.$('#login--dialog');
|
|
|
|
const userInput = await signInDialog.$('#login--dialog-username');
|
|
|
|
expect(userInput).not.toBeNull();
|
|
|
|
const passInput = await signInDialog.$('#login--dialog-password');
|
|
|
|
expect(passInput).not.toBeNull();
|
|
|
|
await userInput.type('test', { delay: 100 });
|
|
|
|
await passInput.type('test', { delay: 100 });
|
|
|
|
await passInput.dispose();
|
|
|
|
// click on log in
|
|
|
|
const loginButton = await page.$('#login--dialog-button-submit');
|
|
|
|
expect(loginButton).toBeDefined();
|
|
|
|
await loginButton.focus();
|
|
|
|
await loginButton.click({ delay: 100 });
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(500);
|
2020-12-22 13:10:20 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
beforeAll(async () => {
|
|
|
|
page = await global.__BROWSER__.newPage();
|
|
|
|
await page.goto('http://0.0.0.0:55558');
|
|
|
|
page.on('console', (msg) => console.log('PAGE LOG:', msg.text()));
|
|
|
|
});
|
|
|
|
|
|
|
|
afterAll(async () => {
|
|
|
|
await page.close();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should display title', async () => {
|
|
|
|
const text = await page.title();
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2020-12-22 13:10:20 +01:00
|
|
|
|
|
|
|
expect(text).toContain('verdaccio-server-e2e');
|
|
|
|
});
|
|
|
|
//
|
|
|
|
|
|
|
|
test('should match title with no packages published', async () => {
|
|
|
|
const text = await page.evaluate(() => document.querySelector('#help-card__title').textContent);
|
|
|
|
expect(text).toMatch('No Package Published Yet.');
|
|
|
|
});
|
|
|
|
//
|
|
|
|
|
|
|
|
test('should match title with first step', async () => {
|
|
|
|
const text = await page.evaluate(() => document.querySelector('#help-card').textContent);
|
|
|
|
expect(text).toContain('npm adduser --registry http://0.0.0.0:55558');
|
|
|
|
});
|
|
|
|
//
|
|
|
|
|
|
|
|
test('should match title with second step', async () => {
|
|
|
|
const text = await page.evaluate(() => document.querySelector('#help-card').textContent);
|
|
|
|
expect(text).toContain('npm publish --registry http://0.0.0.0:55558');
|
|
|
|
});
|
|
|
|
//
|
|
|
|
|
|
|
|
test('should match button Login to sign in', async () => {
|
|
|
|
await evaluateSignIn();
|
|
|
|
});
|
|
|
|
//
|
|
|
|
|
|
|
|
test('should click on sign in button', async () => {
|
|
|
|
const signInButton = await page.$('button[data-testid="header--button-login"]');
|
|
|
|
await signInButton.click();
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2020-12-22 13:10:20 +01:00
|
|
|
const signInDialog = await page.$('#login--dialog');
|
|
|
|
expect(signInDialog).not.toBeNull();
|
|
|
|
const closeButton = await page.$('button[data-testid="close-login-dialog-button"]');
|
|
|
|
await closeButton.click();
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(500);
|
2020-12-22 13:10:20 +01:00
|
|
|
});
|
|
|
|
//
|
|
|
|
|
|
|
|
test('should log in an user', async () => {
|
|
|
|
// we open the dialog
|
|
|
|
await logIn();
|
2021-05-05 23:23:03 +02:00
|
|
|
// verify if logged in
|
|
|
|
const accountButton = await page.$('#header--button-account');
|
|
|
|
expect(accountButton).toBeDefined();
|
2020-12-22 13:10:20 +01:00
|
|
|
// check whether user is logged
|
2021-09-25 17:35:03 +02:00
|
|
|
const buttonLogout = await page.$('#logOutDialogIcon');
|
2020-12-22 13:10:20 +01:00
|
|
|
expect(buttonLogout).toBeDefined();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should logout an user', async () => {
|
2021-05-05 23:23:03 +02:00
|
|
|
// await wa
|
|
|
|
await page.waitForTimeout(10000);
|
2020-12-22 13:10:20 +01:00
|
|
|
// we assume the user is logged already
|
|
|
|
await clickElement('#header--button-account', { delay: 500 });
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2021-09-25 17:35:03 +02:00
|
|
|
await clickElement('#logOutDialogIcon > span', { delay: 500 });
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2020-12-22 13:10:20 +01:00
|
|
|
await evaluateSignIn();
|
|
|
|
});
|
|
|
|
//
|
|
|
|
|
|
|
|
test('should check registry info dialog', async () => {
|
|
|
|
const registryInfoButton = await page.$('#header--button-registryInfo');
|
|
|
|
registryInfoButton.click();
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(500);
|
2020-12-22 13:10:20 +01:00
|
|
|
|
|
|
|
const registryInfoDialog = await page.$('#registryInfo--dialog-container');
|
|
|
|
expect(registryInfoDialog).not.toBeNull();
|
|
|
|
|
|
|
|
const closeButton = await page.$('#registryInfo--dialog-close');
|
|
|
|
await closeButton.click();
|
|
|
|
});
|
|
|
|
//
|
|
|
|
|
|
|
|
test('should publish a package', async () => {
|
|
|
|
await global.__SERVER__.putPackage(scopedPackageMetadata.name, scopedPackageMetadata);
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2020-12-22 13:10:20 +01:00
|
|
|
await page.reload();
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2020-12-22 13:10:20 +01:00
|
|
|
const packagesList = await getPackages();
|
|
|
|
expect(packagesList).toHaveLength(1);
|
|
|
|
});
|
|
|
|
//
|
|
|
|
|
|
|
|
test('should navigate to the package detail', async () => {
|
|
|
|
const packagesList = await getPackages();
|
|
|
|
// console.log("-->packagesList:", packagesList);
|
|
|
|
const firstPackage = packagesList[0];
|
|
|
|
await firstPackage.click({ delay: 200 });
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2020-12-22 13:10:20 +01:00
|
|
|
const readmeText = await page.evaluate(
|
|
|
|
() => document.querySelector('.markdown-body').textContent
|
|
|
|
);
|
|
|
|
|
|
|
|
expect(readmeText).toMatch('test');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should contains last sync information', async () => {
|
|
|
|
const versionList = await page.$$('.sidebar-info .detail-info');
|
|
|
|
expect(versionList).toHaveLength(1);
|
|
|
|
});
|
|
|
|
//
|
|
|
|
|
|
|
|
test('should display dependencies tab', async () => {
|
|
|
|
const dependenciesTab = await page.$$('#dependencies-tab');
|
|
|
|
expect(dependenciesTab).toHaveLength(1);
|
|
|
|
await dependenciesTab[0].click({ delay: 200 });
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2020-12-22 13:10:20 +01:00
|
|
|
const tags = await page.$$('.dep-tag');
|
|
|
|
const tag = tags[0];
|
|
|
|
const label = await page.evaluate((el) => el.innerText, tag);
|
|
|
|
expect(label).toMatch('verdaccio@');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should display version tab', async () => {
|
|
|
|
const versionsTab = await page.$$('#versions-tab');
|
|
|
|
expect(versionsTab).toHaveLength(1);
|
|
|
|
await versionsTab[0].click({ delay: 200 });
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2020-12-22 13:10:20 +01:00
|
|
|
const versionItems = await page.$$('.version-item');
|
|
|
|
expect(versionItems).toHaveLength(2);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should display uplinks tab', async () => {
|
|
|
|
const upLinksTab = await page.$$('#uplinks-tab');
|
|
|
|
expect(upLinksTab).toHaveLength(1);
|
|
|
|
await upLinksTab[0].click({ delay: 200 });
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2020-12-22 13:10:20 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
test('should display readme tab', async () => {
|
|
|
|
const readmeTab = await page.$$('#readme-tab');
|
|
|
|
expect(readmeTab).toHaveLength(1);
|
|
|
|
await readmeTab[0].click({ delay: 200 });
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(1000);
|
2020-12-22 13:10:20 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
test('should publish a protected package', async () => {
|
|
|
|
await page.goto('http://0.0.0.0:55552');
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(500);
|
2020-12-22 13:10:20 +01:00
|
|
|
await global.__SERVER_PROTECTED__.putPackage(
|
|
|
|
protectedPackageMetadata.name,
|
|
|
|
protectedPackageMetadata
|
|
|
|
);
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(500);
|
2020-12-22 13:10:20 +01:00
|
|
|
await page.reload();
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(500);
|
2020-12-22 13:10:20 +01:00
|
|
|
const text = await page.evaluate(() => document.querySelector('#help-card__title').textContent);
|
|
|
|
expect(text).toMatch('No Package Published Yet');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should go to 404 page', async () => {
|
|
|
|
await page.goto('http://0.0.0.0:55552/-/web/detail/@verdaccio/not-found');
|
2021-05-05 23:23:03 +02:00
|
|
|
await page.waitForTimeout(500);
|
2020-12-22 13:10:20 +01:00
|
|
|
const text = await page.evaluate(() => document.querySelector('.not-found-text').textContent);
|
|
|
|
expect(text).toMatch("Sorry, we couldn't find it...");
|
|
|
|
});
|
|
|
|
});
|