2019-06-13 18:28:43 +02:00
|
|
|
/**
|
|
|
|
* PLEASE DO NOT MODIFY THIS FILE
|
|
|
|
*
|
|
|
|
* This test is just for teaching purpose, use this example as template for your new endpoint API unit test
|
|
|
|
*
|
|
|
|
* If you have any questions, ask at the http://chat.verdaccio.org #questions channel.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
import request from 'supertest';
|
|
|
|
import _ from 'lodash';
|
|
|
|
import path from 'path';
|
|
|
|
import rimraf from 'rimraf';
|
|
|
|
|
2019-06-13 22:04:35 +02:00
|
|
|
import endPointAPI from '../../../../src/api/index';
|
2021-03-14 08:42:46 +01:00
|
|
|
import { mockServer } from '../../__helper/mock';
|
|
|
|
import { DOMAIN_SERVERS } from '../../../functional/config.functional';
|
|
|
|
import { parseConfigFile } from '../../../../src/lib/utils';
|
|
|
|
import { parseConfigurationFile } from '../../__helper';
|
|
|
|
import { addUser } from '../../__helper/api';
|
|
|
|
import { setup } from '../../../../src/lib/logger';
|
2019-06-13 18:28:43 +02:00
|
|
|
|
|
|
|
// we must start logging without output
|
|
|
|
setup([]);
|
|
|
|
|
|
|
|
const parseConfigurationJWTFile = () => {
|
|
|
|
// Any new test must have a custom yaml file, try to name it based on the feature, the config
|
|
|
|
// file does not need to include all configuration, just the part is needs
|
|
|
|
// eg: test/unit/partials/config/yaml/api-jwt/jwt.yaml
|
|
|
|
return parseConfigurationFile(`api-jwt/jwt`);
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('endpoint example unit test', () => {
|
|
|
|
let app;
|
|
|
|
let mockRegistry;
|
|
|
|
|
2021-03-14 08:42:46 +01:00
|
|
|
beforeAll(function (done) {
|
2019-06-13 18:28:43 +02:00
|
|
|
// 1. We create a route for a custom storage folder for this test
|
2019-06-13 22:16:40 +02:00
|
|
|
const store = path.join(__dirname, '../../partials/store/test-template-storage');
|
2019-06-13 18:28:43 +02:00
|
|
|
// 2. The port must be unique (at this point this is not automated, need to be checked manually)
|
|
|
|
const mockServerPort = 55546;
|
|
|
|
// 3. Use rimraf to clean the state each time you run the test
|
|
|
|
rimraf(store, async () => {
|
|
|
|
// 4. Use a custom configuration file
|
|
|
|
const confS = parseConfigFile(parseConfigurationJWTFile());
|
|
|
|
// 5. Customise specific properties
|
|
|
|
const configForTest = _.assign({}, _.cloneDeep(confS), {
|
|
|
|
storage: store,
|
|
|
|
uplinks: {
|
|
|
|
npmjs: {
|
|
|
|
url: `http://${DOMAIN_SERVERS}:${mockServerPort}`
|
|
|
|
}
|
|
|
|
},
|
|
|
|
// 6. The self_path is important be the same as the store
|
|
|
|
self_path: store,
|
|
|
|
// 7. Define the location of the .htpasswd file, this is relative to self_path.
|
|
|
|
auth: {
|
|
|
|
htpasswd: {
|
|
|
|
file: './test-jwt-storage/.htpasswd'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// 8. Use the helper `endPointAPI` to mock the API
|
|
|
|
app = await endPointAPI(configForTest);
|
|
|
|
// 9 . Use `mockServer` to mock launch the server.
|
|
|
|
mockRegistry = await mockServer(mockServerPort).init();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2021-03-14 08:42:46 +01:00
|
|
|
afterAll(function (done) {
|
2019-06-13 18:28:43 +02:00
|
|
|
// 10. Do not forget to stop the API, or it will run forever.
|
|
|
|
mockRegistry[0].stop();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should test add a new user with JWT enabled', async (done) => {
|
|
|
|
// At this point the server is running and you can run the test
|
|
|
|
|
|
|
|
const credentials = { name: 'JotaJWT', password: 'secretPass' };
|
|
|
|
// 11. Use helpers for repetitive tasks
|
2019-07-16 08:40:01 +02:00
|
|
|
// @ts-ignore
|
2019-06-13 18:28:43 +02:00
|
|
|
const [err, res] = await addUser(request(app), credentials.name, credentials);
|
|
|
|
|
|
|
|
// 12. test your output
|
|
|
|
expect(err).toBeNull();
|
|
|
|
expect(res.body.ok).toBeDefined();
|
|
|
|
expect(res.body.token).toBeDefined();
|
|
|
|
|
|
|
|
// 13. end the async test
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|