mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-20 22:52:46 -05:00
9f6106cfe9
* chore: fix unit test, forgotten line on merge chore: add node 11 to circleci (#1153) chore: fix the use of Node 11 in CircleCI (#1154) refactor: added css in js, new design, added types feat: added Tag component refactor: added modifiers refactor: replaced by polished ellipsis refactor: added types, new design and css in js refactor: removed ul. it needs refactor refactor: changed media queries refactor: changed icon height refactor: changed Header media queries refactor: removed margin top refactor: updated snapshots refactor: removed unnecessary format author refactor: added license icon & changed size refactor: changed media queries refactor: added icon size refactor: changed media queries refactor: updated snap refactor: replaced Description by Details refactor: updated tests refactor: fixed modifiers type feat: created missed types fix: fixed types fix: fixed prop type fix: fixed undefined prop refactor: replaced label by name refactor: updated snap refactor: moved polished to dev refactor: changed formatAuthor and pkg author type fix: removed incorrect meta's type refactor: removed polished refactor: added spacing & ellipsis mixin refactor: added modifier type refactor: changed datetime format refactor: updated snapshots refactor: rreplaced polished by mixins func * refactor: updated styled * fix: added missed semicolon * refactor: updated media * refactor: updated tests * refactor: organized modifiers * refactor: removed unused imports * refactor: design adjusts * refactor: updated snapshot * refactor: changed minor things * refactor: updated snapshots * refactor: commented tests. fix later
156 lines
5.4 KiB
JavaScript
156 lines
5.4 KiB
JavaScript
/**
|
|
* @prettier
|
|
*/
|
|
|
|
const scopedPackageMetadata = require('./partials/pkg-scoped');
|
|
const protectedPackageMetadata = require('./partials/pkg-protected');
|
|
|
|
describe('/ (Verdaccio Page)', () => {
|
|
let page;
|
|
// this might be increased based on the delays included in all test
|
|
jest.setTimeout(200000);
|
|
|
|
const clickElement = async function(selector, options = { button: 'middle', delay: 100 }) {
|
|
const button = await page.$(selector);
|
|
await button.focus();
|
|
await button.click(options);
|
|
};
|
|
|
|
const evaluateSignIn = async function() {
|
|
const text = await page.evaluate(() => document.querySelector('#header--button-login').textContent);
|
|
expect(text).toMatch('Login');
|
|
};
|
|
|
|
const getPackages = async function() {
|
|
return await page.$$('.package-list-items .package');
|
|
};
|
|
|
|
const logIn = async function() {
|
|
await clickElement('#header--button-login');
|
|
await page.waitFor(500);
|
|
// we fill the sign in form
|
|
const signInDialog = await page.$('#login--form-container');
|
|
const userInput = await signInDialog.$('#login--form-username');
|
|
expect(userInput).not.toBeNull();
|
|
const passInput = await signInDialog.$('#login--form-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--form-submit');
|
|
expect(loginButton).toBeDefined();
|
|
await loginButton.focus();
|
|
await loginButton.click({ delay: 100 });
|
|
await page.waitFor(500);
|
|
};
|
|
|
|
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();
|
|
});
|
|
|
|
it('should load without error', async () => {
|
|
const text = await page.evaluate(() => document.body.textContent);
|
|
|
|
// FIXME: perhaps it is not the best approach
|
|
expect(text).toContain('Powered by');
|
|
});
|
|
|
|
it('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');
|
|
});
|
|
|
|
it('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');
|
|
});
|
|
|
|
it('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');
|
|
});
|
|
|
|
it('should match button Login to sign in', async () => {
|
|
await evaluateSignIn();
|
|
});
|
|
|
|
it('should click on sign in button', async () => {
|
|
const signInButton = await page.$('#header--button-login');
|
|
await signInButton.click();
|
|
await page.waitFor(1000);
|
|
const signInDialog = await page.$('#login--form-container');
|
|
|
|
expect(signInDialog).not.toBeNull();
|
|
});
|
|
|
|
it('should log in an user', async () => {
|
|
// we open the dialog
|
|
await logIn();
|
|
// check whether user is logged
|
|
const buttonLogout = await page.$('#header--button-logout');
|
|
expect(buttonLogout).toBeDefined();
|
|
});
|
|
|
|
it('should logout an user', async () => {
|
|
// we assume the user is logged already
|
|
await clickElement('#header--button-account', { clickCount: 1, delay: 500 });
|
|
await page.waitFor(1000);
|
|
await clickElement('#header--button-logout > span', { clickCount: 1, delay: 500 });
|
|
await page.waitFor(1000);
|
|
await evaluateSignIn();
|
|
});
|
|
|
|
it('should check registry info dialog', async () => {
|
|
const registryInfoButton = await page.$('#header--button-registryInfo');
|
|
registryInfoButton.click();
|
|
await page.waitFor(500);
|
|
|
|
const registryInfoDialog = await page.$('#registryInfo--dialog-container');
|
|
expect(registryInfoDialog).not.toBeNull();
|
|
|
|
const closeButton = await page.$('#registryInfo--dialog-close');
|
|
closeButton.click();
|
|
});
|
|
|
|
it('should publish a package', async () => {
|
|
await global.__SERVER__.putPackage(scopedPackageMetadata.name, scopedPackageMetadata);
|
|
await page.waitFor(1000);
|
|
await page.reload();
|
|
await page.waitFor(1000);
|
|
const packagesList = await getPackages();
|
|
expect(packagesList).toHaveLength(1);
|
|
});
|
|
|
|
it('should navigate to the package detail', async () => {
|
|
const packagesList = await getPackages();
|
|
const firstPackage = packagesList[0];
|
|
await firstPackage.focus();
|
|
await firstPackage.click({ clickCount: 1, delay: 200 });
|
|
await page.waitFor(1000);
|
|
const readmeText = await page.evaluate(() => document.querySelector('.markdown-body').textContent);
|
|
expect(readmeText).toMatch('test');
|
|
});
|
|
|
|
it('should contains last sync information', async () => {
|
|
const versionList = await page.$$('.sidebar-info .last-sync-item');
|
|
expect(versionList).toHaveLength(3);
|
|
});
|
|
|
|
it('should publish a protected package', async () => {
|
|
await page.goto('http://0.0.0.0:55552');
|
|
await page.waitFor(500);
|
|
await global.__SERVER_PROTECTED__.putPackage(protectedPackageMetadata.name, protectedPackageMetadata);
|
|
await page.waitFor(500);
|
|
await page.reload();
|
|
await page.waitFor(500);
|
|
const text = await page.evaluate(() => document.querySelector('#help-card__title').textContent);
|
|
expect(text).toMatch('No Package Published Yet');
|
|
});
|
|
});
|