import path from 'path'; import supertest from 'supertest'; import { API_ERROR, HEADERS, HEADER_TYPE, HTTP_STATUS } from '@verdaccio/core'; import { setup } from '@verdaccio/logger'; import { initializeServer } from './helper'; setup([]); const mockManifest = jest.fn(); jest.mock('@verdaccio/ui-theme', () => mockManifest()); describe('test web server', () => { beforeAll(() => { mockManifest.mockReturnValue(() => ({ staticPath: path.join(__dirname, 'static'), manifestFiles: { js: ['runtime.js', 'vendors.js', 'main.js'], }, manifest: require('./partials/manifest/manifest.json'), })); }); afterEach(() => { jest.clearAllMocks(); mockManifest.mockClear(); }); test('should get 401', async () => { return supertest(await initializeServer('default-test.yaml')) .post('/-/verdaccio/sec/login') .send( JSON.stringify({ username: 'test', password: 'password1', }) ) .set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON) .expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET) .expect(HTTP_STATUS.UNAUTHORIZED) .then((response) => { expect(response.body.error).toEqual(API_ERROR.BAD_USERNAME_PASSWORD); }); }); test('should log in', async () => { return supertest(await initializeServer('default-test.yaml')) .post('/-/verdaccio/sec/login') .send( JSON.stringify({ username: 'test', password: 'test', }) ) .set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON) .expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET) .expect(HEADERS.CACHE_CONTROL, 'no-cache, no-store') .expect(HTTP_STATUS.OK) .then((res) => { expect(res.body.error).toBeUndefined(); expect(res.body.token).toBeDefined(); expect(res.body.token).toBeTruthy(); expect(res.body.username).toMatch('test'); }); }); test.skip('log in should be disabled', async () => { return supertest(await initializeServer('login-disabled.yaml')) .post('/-/verdaccio/sec/login') .send( JSON.stringify({ username: 'test', password: 'test', }) ) .set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON) .expect(HTTP_STATUS.NOT_FOUND); }); test.todo('should change password'); test.todo('should not change password if flag is disabled'); });