2021-03-06 18:56:45 +01:00
|
|
|
import path from 'path';
|
|
|
|
import supertest from 'supertest';
|
2021-10-29 17:33:05 +02:00
|
|
|
|
|
|
|
import { API_ERROR, HEADERS, HEADER_TYPE, HTTP_STATUS } from '@verdaccio/core';
|
2021-03-06 18:56:45 +01:00
|
|
|
import { setup } from '@verdaccio/logger';
|
2021-10-29 17:33:05 +02:00
|
|
|
|
2021-03-06 18:56:45 +01:00
|
|
|
import { initializeServer } from './helper';
|
|
|
|
|
|
|
|
setup([]);
|
|
|
|
|
|
|
|
const mockManifest = jest.fn();
|
|
|
|
jest.mock('@verdaccio/ui-theme', () => mockManifest());
|
|
|
|
|
|
|
|
describe('test web server', () => {
|
|
|
|
beforeAll(() => {
|
2021-04-02 15:59:47 +02:00
|
|
|
mockManifest.mockReturnValue(() => ({
|
|
|
|
staticPath: path.join(__dirname, 'static'),
|
|
|
|
manifestFiles: {
|
|
|
|
js: ['runtime.js', 'vendors.js', 'main.js'],
|
|
|
|
},
|
2021-03-06 18:56:45 +01:00
|
|
|
manifest: require('./partials/manifest/manifest.json'),
|
2021-04-02 15:59:47 +02:00
|
|
|
}));
|
2021-03-06 18:56:45 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
jest.clearAllMocks();
|
|
|
|
mockManifest.mockClear();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should get 401', async () => {
|
|
|
|
return supertest(await initializeServer('default-test.yaml'))
|
2022-01-15 20:12:28 +01:00
|
|
|
.post('/-/verdaccio/sec/login')
|
2021-03-06 18:56:45 +01:00
|
|
|
.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'))
|
2022-01-15 20:12:28 +01:00
|
|
|
.post('/-/verdaccio/sec/login')
|
2021-03-06 18:56:45 +01:00
|
|
|
.send(
|
|
|
|
JSON.stringify({
|
|
|
|
username: 'test',
|
|
|
|
password: 'test',
|
|
|
|
})
|
|
|
|
)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET)
|
2022-10-28 23:38:22 +02:00
|
|
|
.expect(HEADERS.CACHE_CONTROL, 'no-cache, no-store')
|
2021-03-06 18:56:45 +01:00
|
|
|
.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');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2022-03-27 21:42:52 +02:00
|
|
|
test.skip('log in should be disabled', async () => {
|
2021-05-05 23:23:03 +02:00
|
|
|
return supertest(await initializeServer('login-disabled.yaml'))
|
2022-01-15 20:12:28 +01:00
|
|
|
.post('/-/verdaccio/sec/login')
|
2021-05-05 23:23:03 +02:00
|
|
|
.send(
|
|
|
|
JSON.stringify({
|
|
|
|
username: 'test',
|
|
|
|
password: 'test',
|
|
|
|
})
|
|
|
|
)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.expect(HTTP_STATUS.NOT_FOUND);
|
|
|
|
});
|
|
|
|
|
2021-03-06 18:56:45 +01:00
|
|
|
test.todo('should change password');
|
|
|
|
test.todo('should not change password if flag is disabled');
|
|
|
|
});
|