2020-08-13 23:27:00 +02:00
|
|
|
import supertest from 'supertest';
|
2021-10-29 17:33:05 +02:00
|
|
|
|
|
|
|
import { HTTP_STATUS } from '@verdaccio/core';
|
|
|
|
import { API_ERROR, API_MESSAGE, HEADERS, HEADER_TYPE } from '@verdaccio/core';
|
2022-03-27 21:42:52 +02:00
|
|
|
import { generatePackageMetadata } from '@verdaccio/test-helper';
|
2021-10-29 17:33:05 +02:00
|
|
|
|
|
|
|
import { $RequestExtend, $ResponseExtend } from '../../types/custom';
|
2020-08-13 23:27:00 +02:00
|
|
|
import { initializeServer, publishVersion } from './_helper';
|
|
|
|
|
2020-09-17 06:48:16 +02:00
|
|
|
const mockApiJWTmiddleware = jest.fn(
|
2021-05-16 17:11:08 +02:00
|
|
|
() =>
|
|
|
|
(req: $RequestExtend, res: $ResponseExtend, _next): void => {
|
|
|
|
req.remote_user = { name: 'foo', groups: [], real_groups: [] };
|
|
|
|
_next();
|
|
|
|
}
|
2020-09-17 06:48:16 +02:00
|
|
|
);
|
2020-06-30 21:55:14 +02:00
|
|
|
|
|
|
|
jest.mock('@verdaccio/auth', () => ({
|
2020-08-13 23:27:00 +02:00
|
|
|
Auth: class {
|
|
|
|
apiJWTmiddleware() {
|
|
|
|
return mockApiJWTmiddleware();
|
|
|
|
}
|
|
|
|
allow_access(_d, f_, cb) {
|
|
|
|
cb(null, true);
|
|
|
|
}
|
|
|
|
allow_publish(_d, f_, cb) {
|
|
|
|
cb(null, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
allow_unpublish(_d, f_, cb) {
|
|
|
|
cb(null, true);
|
|
|
|
}
|
|
|
|
},
|
2020-06-30 21:55:14 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
// const mockStorage = jest.fn(() => {
|
|
|
|
// const { Storage } = jest.requireActual('@verdaccio/store');
|
|
|
|
// return {
|
|
|
|
// Storage: class extends Storage {
|
|
|
|
// addPackage(name, metadata, cb) {
|
|
|
|
// super.addPackage(name, metadata, cb);
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// };
|
|
|
|
// });
|
|
|
|
|
|
|
|
// jest.mock('@verdaccio/store', () => {
|
|
|
|
// const { Storage } = jest.requireActual('@verdaccio/store');
|
|
|
|
// return ({
|
|
|
|
// Storage: class extends Storage {
|
|
|
|
// addPackage(name, metadata, cb) {
|
|
|
|
// // super.addPackage(name, metadata, cb);
|
|
|
|
// return mockStorage(name, metadata, cb);
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// })
|
|
|
|
// });
|
|
|
|
|
|
|
|
describe('publish', () => {
|
2020-08-13 23:27:00 +02:00
|
|
|
describe('handle invalid publish formats', () => {
|
|
|
|
const pkgName = 'test';
|
|
|
|
const pkgMetadata = generatePackageMetadata(pkgName, '1.0.0');
|
2022-07-29 20:51:45 +02:00
|
|
|
test('should fail on publish a bad _attachments package', async () => {
|
2020-08-13 23:27:00 +02:00
|
|
|
const app = await initializeServer('publish.yaml');
|
2022-07-29 20:51:45 +02:00
|
|
|
const response = await supertest(app)
|
2020-08-13 23:27:00 +02:00
|
|
|
.put(`/${encodeURIComponent(pkgName)}`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.send(
|
|
|
|
JSON.stringify(
|
|
|
|
Object.assign({}, pkgMetadata, {
|
|
|
|
_attachments: {},
|
|
|
|
})
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.set('accept', HEADERS.GZIP)
|
2022-07-29 20:51:45 +02:00
|
|
|
.expect(HTTP_STATUS.BAD_REQUEST);
|
|
|
|
expect(response.body.error).toEqual(API_ERROR.UNSUPORTED_REGISTRY_CALL);
|
2020-08-13 23:27:00 +02:00
|
|
|
});
|
|
|
|
|
2021-06-13 09:14:04 +02:00
|
|
|
test('should fail on publish a bad versions package', async () => {
|
2020-08-13 23:27:00 +02:00
|
|
|
const app = await initializeServer('publish.yaml');
|
2021-06-13 09:14:04 +02:00
|
|
|
return new Promise((resolve) => {
|
|
|
|
supertest(app)
|
|
|
|
.put(`/${encodeURIComponent(pkgName)}`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.send(
|
|
|
|
JSON.stringify(
|
|
|
|
Object.assign({}, pkgMetadata, {
|
|
|
|
versions: '',
|
|
|
|
})
|
|
|
|
)
|
2020-08-13 23:27:00 +02:00
|
|
|
)
|
2021-06-13 09:14:04 +02:00
|
|
|
.set('accept', HEADERS.GZIP)
|
|
|
|
.expect(HTTP_STATUS.BAD_REQUEST)
|
|
|
|
.then((response) => {
|
|
|
|
expect(response.body.error).toEqual(API_ERROR.UNSUPORTED_REGISTRY_CALL);
|
|
|
|
resolve(response);
|
|
|
|
});
|
|
|
|
});
|
2020-08-13 23:27:00 +02:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('publish a package', () => {
|
2021-06-13 09:14:04 +02:00
|
|
|
test('should publish a package', async () => {
|
2020-08-13 23:27:00 +02:00
|
|
|
const app = await initializeServer('publish.yaml');
|
2021-06-13 09:14:04 +02:00
|
|
|
return new Promise((resolve) => {
|
2022-07-29 20:51:45 +02:00
|
|
|
publishVersion(app, 'foo', '1.0.0')
|
2021-06-13 09:14:04 +02:00
|
|
|
.expect(HTTP_STATUS.CREATED)
|
|
|
|
.then((response) => {
|
|
|
|
expect(response.body.ok).toEqual(API_MESSAGE.PKG_CREATED);
|
|
|
|
resolve(response);
|
|
|
|
});
|
|
|
|
});
|
2020-08-13 23:27:00 +02:00
|
|
|
});
|
|
|
|
|
2021-06-13 09:14:04 +02:00
|
|
|
test('should publish a new package', async () => {
|
2020-08-13 23:27:00 +02:00
|
|
|
const pkgName = 'test';
|
|
|
|
const pkgMetadata = generatePackageMetadata(pkgName, '1.0.0');
|
|
|
|
const app = await initializeServer('publish.yaml');
|
2021-06-13 09:14:04 +02:00
|
|
|
return new Promise((resolve) => {
|
|
|
|
supertest(app)
|
|
|
|
.put(`/${encodeURIComponent(pkgName)}`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
2022-07-29 20:51:45 +02:00
|
|
|
.send(JSON.stringify(Object.assign({}, pkgMetadata)))
|
2021-06-13 09:14:04 +02:00
|
|
|
.set('accept', HEADERS.GZIP)
|
|
|
|
.expect(HTTP_STATUS.CREATED)
|
|
|
|
.then((response) => {
|
|
|
|
expect(response.body.ok).toEqual(API_MESSAGE.PKG_CREATED);
|
|
|
|
resolve(response);
|
|
|
|
});
|
|
|
|
});
|
2020-08-13 23:27:00 +02:00
|
|
|
});
|
|
|
|
|
2021-06-13 09:14:04 +02:00
|
|
|
test('should publish a new package with no readme', async () => {
|
2020-08-13 23:27:00 +02:00
|
|
|
const pkgName = 'test';
|
|
|
|
const pkgMetadata = generatePackageMetadata(pkgName, '1.0.0');
|
|
|
|
const app = await initializeServer('publish.yaml');
|
2021-06-13 09:14:04 +02:00
|
|
|
return new Promise((resolve) => {
|
|
|
|
supertest(app)
|
|
|
|
.put(`/${encodeURIComponent(pkgName)}`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.send(
|
|
|
|
JSON.stringify(
|
|
|
|
Object.assign({}, pkgMetadata, {
|
|
|
|
versions: {
|
|
|
|
['1.0.0']: {
|
|
|
|
readme: null,
|
|
|
|
},
|
2020-08-13 23:27:00 +02:00
|
|
|
},
|
2021-06-13 09:14:04 +02:00
|
|
|
})
|
|
|
|
)
|
2020-08-13 23:27:00 +02:00
|
|
|
)
|
2021-06-13 09:14:04 +02:00
|
|
|
.set('accept', HEADERS.GZIP)
|
|
|
|
.expect(HTTP_STATUS.CREATED)
|
|
|
|
.then((response) => {
|
|
|
|
expect(response.body.ok).toEqual(API_MESSAGE.PKG_CREATED);
|
|
|
|
resolve(response);
|
|
|
|
});
|
|
|
|
});
|
2020-08-13 23:27:00 +02:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2021-06-13 09:14:04 +02:00
|
|
|
test('should fails on publish a duplicated package', async () => {
|
2020-08-13 23:27:00 +02:00
|
|
|
const app = await initializeServer('publish.yaml');
|
2022-07-29 20:51:45 +02:00
|
|
|
await publishVersion(app, 'foo', '1.0.0');
|
2021-06-13 09:14:04 +02:00
|
|
|
return new Promise((resolve) => {
|
2022-07-29 20:51:45 +02:00
|
|
|
publishVersion(app, 'foo', '1.0.0')
|
2021-06-13 09:14:04 +02:00
|
|
|
.expect(HTTP_STATUS.CONFLICT)
|
|
|
|
.then((response) => {
|
|
|
|
expect(response.body.error).toEqual(API_ERROR.PACKAGE_EXIST);
|
|
|
|
resolve(response);
|
|
|
|
});
|
|
|
|
});
|
2020-08-13 23:27:00 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('unpublish a package', () => {
|
2022-07-29 20:51:45 +02:00
|
|
|
test('should unpublish entirely a package', async () => {
|
|
|
|
const app = await initializeServer('publish.yaml');
|
|
|
|
await publishVersion(app, 'foo', '1.0.0');
|
|
|
|
const response = await supertest(app)
|
|
|
|
// FIXME: should be filtered by revision to avoid
|
|
|
|
// conflicts
|
|
|
|
.delete(`/${encodeURIComponent('foo')}/-rev/xxx`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.expect(HTTP_STATUS.CREATED);
|
|
|
|
expect(response.body.ok).toEqual(API_MESSAGE.PKG_REMOVED);
|
|
|
|
// package should be completely un published
|
|
|
|
await supertest(app)
|
|
|
|
.get('/foo')
|
|
|
|
.set('Accept', HEADERS.JSON)
|
|
|
|
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET)
|
|
|
|
.expect(HTTP_STATUS.NOT_FOUND);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should fails unpublish entirely a package', async () => {
|
|
|
|
const app = await initializeServer('publish.yaml');
|
|
|
|
const response = await supertest(app)
|
|
|
|
.delete(`/${encodeURIComponent('foo')}/-rev/1cf3-fe3`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.expect(HTTP_STATUS.NOT_FOUND);
|
|
|
|
expect(response.body.error).toEqual(API_ERROR.NO_PACKAGE);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should fails remove a tarball of a package does not exist', async () => {
|
|
|
|
const app = await initializeServer('publish.yaml');
|
|
|
|
const response = await supertest(app)
|
|
|
|
.delete(`/foo/-/foo-1.0.3.tgz/-rev/revision`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.expect(HTTP_STATUS.NOT_FOUND);
|
|
|
|
expect(response.body.error).toEqual(API_ERROR.NO_PACKAGE);
|
|
|
|
});
|
2020-08-13 23:27:00 +02:00
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
test('should fails on try remove a tarball does not exist', async () => {
|
|
|
|
const app = await initializeServer('publish.yaml');
|
|
|
|
await publishVersion(app, 'foo', '1.0.0');
|
|
|
|
const response = await supertest(app)
|
|
|
|
.delete(`/foo/-/foo-1.0.3.tgz/-rev/revision`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.expect(HTTP_STATUS.NOT_FOUND);
|
|
|
|
expect(response.body.error).toEqual(API_ERROR.NO_SUCH_FILE);
|
2020-08-13 23:27:00 +02:00
|
|
|
});
|
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
test('should remove a tarball that does exist', async () => {
|
|
|
|
const app = await initializeServer('publish.yaml');
|
|
|
|
await publishVersion(app, 'foo', '1.0.0');
|
|
|
|
const response = await supertest(app)
|
|
|
|
.delete(`/foo/-/foo-1.0.0.tgz/-rev/revision`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.expect(HTTP_STATUS.CREATED);
|
|
|
|
expect(response.body.ok).toEqual(API_MESSAGE.TARBALL_REMOVED);
|
|
|
|
});
|
2020-08-13 23:27:00 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('star a package', () => {});
|
2020-06-30 21:55:14 +02:00
|
|
|
});
|