2022-06-20 15:05:39 +00:00
|
|
|
import { Fixtures } from '../../../../test/fixtures';
|
2022-03-03 09:35:26 +00:00
|
|
|
import { GlobalConfig } from '../../../config/global';
|
2022-06-20 15:05:39 +00:00
|
|
|
import { extractPackageFile } from '.';
|
|
|
|
|
|
|
|
const requirements1 = Fixtures.get('requirements1.txt');
|
|
|
|
const requirements2 = Fixtures.get('requirements2.txt');
|
|
|
|
const requirements3 = Fixtures.get('requirements3.txt');
|
|
|
|
const requirements4 = Fixtures.get('requirements4.txt');
|
|
|
|
const requirements5 = Fixtures.get('requirements5.txt');
|
|
|
|
const requirements6 = Fixtures.get('requirements6.txt');
|
|
|
|
const requirements7 = Fixtures.get('requirements7.txt');
|
|
|
|
const requirements8 = Fixtures.get('requirements8.txt');
|
|
|
|
const requirementsWithEnvMarkers = Fixtures.get('requirements-env-markers.txt');
|
|
|
|
const requirementsGitPackages = Fixtures.get('requirements-git-packages.txt');
|
2020-07-07 04:28:50 +00:00
|
|
|
|
2022-03-03 09:35:26 +00:00
|
|
|
describe('modules/manager/pip_requirements/extract', () => {
|
2020-07-07 04:28:50 +00:00
|
|
|
beforeEach(() => {
|
|
|
|
delete process.env.PIP_TEST_TOKEN;
|
2021-11-23 20:10:45 +00:00
|
|
|
GlobalConfig.reset();
|
2020-07-07 04:28:50 +00:00
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2020-07-07 04:28:50 +00:00
|
|
|
afterEach(() => {
|
|
|
|
delete process.env.PIP_TEST_TOKEN;
|
2021-11-23 20:10:45 +00:00
|
|
|
GlobalConfig.reset();
|
2020-07-07 04:28:50 +00:00
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2018-11-04 17:51:23 +00:00
|
|
|
describe('extractPackageFile()', () => {
|
2021-01-20 09:07:26 +00:00
|
|
|
const OLD_ENV = process.env;
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2018-04-28 18:39:07 +00:00
|
|
|
beforeEach(() => {
|
2021-01-20 09:07:26 +00:00
|
|
|
process.env = { ...OLD_ENV };
|
|
|
|
delete process.env.PIP_INDEX_URL;
|
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2021-01-20 09:07:26 +00:00
|
|
|
afterEach(() => {
|
|
|
|
process.env = OLD_ENV;
|
2018-04-28 18:39:07 +00:00
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2018-05-03 16:09:18 +00:00
|
|
|
it('returns null for empty', () => {
|
2022-06-03 06:46:45 +00:00
|
|
|
expect(extractPackageFile('nothing here')).toBeNull();
|
2018-05-03 16:09:18 +00:00
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2018-04-28 18:39:07 +00:00
|
|
|
it('extracts dependencies', () => {
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirements1);
|
2018-06-05 09:26:08 +00:00
|
|
|
expect(res).toMatchSnapshot();
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.registryUrls).toEqual(['http://example.com/private-pypi/']);
|
|
|
|
expect(res?.deps).toHaveLength(4);
|
2018-06-05 09:26:08 +00:00
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2018-06-05 09:26:08 +00:00
|
|
|
it('extracts multiple dependencies', () => {
|
2022-06-20 15:05:39 +00:00
|
|
|
const res = extractPackageFile(requirements2)?.deps;
|
2018-04-28 18:39:07 +00:00
|
|
|
expect(res).toMatchSnapshot();
|
2018-06-05 09:26:08 +00:00
|
|
|
expect(res).toHaveLength(5);
|
2018-04-28 18:39:07 +00:00
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2018-10-23 04:09:33 +00:00
|
|
|
it('handles comments and commands', () => {
|
2022-06-20 15:05:39 +00:00
|
|
|
const res = extractPackageFile(requirements3)?.deps;
|
2018-10-23 04:09:33 +00:00
|
|
|
expect(res).toMatchSnapshot();
|
|
|
|
expect(res).toHaveLength(5);
|
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2019-06-20 08:25:17 +00:00
|
|
|
it('handles extras and complex index url', () => {
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirements4);
|
2018-11-01 10:46:00 +00:00
|
|
|
expect(res).toMatchSnapshot();
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.registryUrls).toEqual([
|
2019-06-20 08:25:17 +00:00
|
|
|
'https://artifactory.company.com/artifactory/api/pypi/python/simple',
|
|
|
|
]);
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.deps).toHaveLength(3);
|
2018-11-01 10:46:00 +00:00
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2019-07-15 20:36:09 +00:00
|
|
|
it('handles extra index url', () => {
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirements5);
|
2019-07-15 20:36:09 +00:00
|
|
|
expect(res).toMatchSnapshot();
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.registryUrls).toEqual([
|
2019-07-15 20:36:09 +00:00
|
|
|
'https://artifactory.company.com/artifactory/api/pypi/python/simple',
|
2022-06-03 06:46:45 +00:00
|
|
|
]);
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.additionalRegistryUrls).toEqual([
|
2019-07-15 20:36:09 +00:00
|
|
|
'http://example.com/private-pypi/',
|
|
|
|
]);
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.deps).toHaveLength(6);
|
2019-07-15 20:36:09 +00:00
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2019-07-15 20:36:09 +00:00
|
|
|
it('handles extra index url and defaults without index to config', () => {
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirements6);
|
2019-07-15 20:36:09 +00:00
|
|
|
expect(res).toMatchSnapshot();
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.additionalRegistryUrls).toEqual([
|
2019-07-15 20:36:09 +00:00
|
|
|
'http://example.com/private-pypi/',
|
|
|
|
]);
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.deps).toHaveLength(6);
|
2019-07-15 20:36:09 +00:00
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2019-07-15 20:36:09 +00:00
|
|
|
it('handles extra index url and defaults without index to pypi', () => {
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirements6);
|
2019-07-15 20:36:09 +00:00
|
|
|
expect(res).toMatchSnapshot();
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.additionalRegistryUrls).toEqual([
|
2019-07-15 20:36:09 +00:00
|
|
|
'http://example.com/private-pypi/',
|
|
|
|
]);
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.deps).toHaveLength(6);
|
2019-07-15 20:36:09 +00:00
|
|
|
});
|
2021-05-10 20:27:59 +00:00
|
|
|
|
|
|
|
it('handles extra spaces around pinned dependency equal signs', () => {
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirements4);
|
2021-05-10 20:27:59 +00:00
|
|
|
expect(res).toMatchSnapshot();
|
|
|
|
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.deps[0].currentValue).toStartWith('==');
|
|
|
|
expect(res?.deps[0].currentVersion).toStartWith('2.0.12');
|
|
|
|
expect(res?.deps[1].currentValue).toStartWith('==');
|
|
|
|
expect(res?.deps[1].currentVersion).toStartWith('4.1.1');
|
|
|
|
expect(res?.deps[2].currentValue).toStartWith('==');
|
|
|
|
expect(res?.deps[2].currentVersion).toStartWith('3.2.1');
|
2021-05-10 20:27:59 +00:00
|
|
|
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.deps).toHaveLength(3);
|
2021-05-10 20:27:59 +00:00
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2020-07-07 04:28:50 +00:00
|
|
|
it('should not replace env vars in low trust mode', () => {
|
|
|
|
process.env.PIP_TEST_TOKEN = 'its-a-secret';
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirements7);
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.additionalRegistryUrls).toEqual([
|
2020-07-07 04:28:50 +00:00
|
|
|
'http://$PIP_TEST_TOKEN:example.com/private-pypi/',
|
|
|
|
'http://${PIP_TEST_TOKEN}:example.com/private-pypi/',
|
|
|
|
'http://$PIP_TEST_TOKEN:example.com/private-pypi/',
|
2022-08-05 13:20:16 +00:00
|
|
|
'http://${PIP_TEST_TOKEN1}:example.com/private-pypi/',
|
2020-07-07 04:28:50 +00:00
|
|
|
]);
|
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2020-07-07 04:28:50 +00:00
|
|
|
it('should replace env vars in high trust mode', () => {
|
|
|
|
process.env.PIP_TEST_TOKEN = 'its-a-secret';
|
2021-11-23 20:10:45 +00:00
|
|
|
GlobalConfig.set({ exposeAllEnv: true });
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirements7);
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.additionalRegistryUrls).toEqual([
|
2020-07-07 04:28:50 +00:00
|
|
|
'http://its-a-secret:example.com/private-pypi/',
|
|
|
|
'http://its-a-secret:example.com/private-pypi/',
|
|
|
|
'http://its-a-secret:example.com/private-pypi/',
|
2022-08-05 13:20:16 +00:00
|
|
|
'http://${PIP_TEST_TOKEN1}:example.com/private-pypi/',
|
2020-07-07 04:28:50 +00:00
|
|
|
]);
|
|
|
|
});
|
2022-01-06 10:47:56 +00:00
|
|
|
|
2021-11-01 20:42:08 +00:00
|
|
|
it('should handle hashes', () => {
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirements8);
|
2021-11-01 20:42:08 +00:00
|
|
|
expect(res).toMatchSnapshot();
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.deps).toHaveLength(3);
|
2021-11-01 20:42:08 +00:00
|
|
|
});
|
2022-01-06 10:47:56 +00:00
|
|
|
|
|
|
|
it('should handle dependency and ignore env markers', () => {
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirementsWithEnvMarkers);
|
2022-01-06 10:47:56 +00:00
|
|
|
expect(res).toEqual({
|
|
|
|
deps: [
|
|
|
|
{
|
|
|
|
currentValue: '==20.3.0',
|
|
|
|
currentVersion: '20.3.0',
|
|
|
|
datasource: 'pypi',
|
|
|
|
depName: 'attrs',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|
|
|
|
});
|
2022-04-12 14:49:49 +00:00
|
|
|
|
2022-01-18 21:18:48 +00:00
|
|
|
it('should handle git packages', () => {
|
2022-06-03 06:46:45 +00:00
|
|
|
const res = extractPackageFile(requirementsGitPackages);
|
2022-06-20 15:05:39 +00:00
|
|
|
expect(res?.deps).toHaveLength(5);
|
2022-01-18 21:18:48 +00:00
|
|
|
expect(res).toEqual({
|
|
|
|
deps: [
|
|
|
|
{
|
|
|
|
depName: 'python-pip-setup-test',
|
|
|
|
currentValue: 'v1.1.0',
|
|
|
|
currentVersion: 'v1.1.0',
|
2022-03-03 15:08:43 +00:00
|
|
|
packageName: 'git@github.com:rwxd/python-pip-setup-test.git',
|
2022-01-18 21:18:48 +00:00
|
|
|
datasource: 'git-tags',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
depName: 'test_package',
|
|
|
|
currentValue: '1.0.0',
|
|
|
|
currentVersion: '1.0.0',
|
2022-03-03 15:08:43 +00:00
|
|
|
packageName: 'git@github.com:rwxd/test_package',
|
2022-01-18 21:18:48 +00:00
|
|
|
datasource: 'git-tags',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
depName: 'python-package',
|
|
|
|
currentValue: 'abcde',
|
|
|
|
currentVersion: 'abcde',
|
2022-03-03 15:08:43 +00:00
|
|
|
packageName: 'git@gitlab.company.com:rwxd/python-package.git',
|
2022-01-18 21:18:48 +00:00
|
|
|
datasource: 'git-tags',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
depName: 'python-pip-setup-test',
|
|
|
|
currentValue: 'v0.9.0',
|
|
|
|
currentVersion: 'v0.9.0',
|
2022-04-29 04:11:11 +00:00
|
|
|
packageName:
|
|
|
|
'https://peter@github.com/rwxd/python-pip-setup-test.git',
|
|
|
|
datasource: 'git-tags',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
depName: 'python-pip-setup-test',
|
|
|
|
currentValue: 'v0.9.0',
|
|
|
|
currentVersion: 'v0.9.0',
|
|
|
|
packageName: 'https://github.com/rwxd/python-pip-setup-test.git',
|
2022-01-18 21:18:48 +00:00
|
|
|
datasource: 'git-tags',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|
|
|
|
});
|
2018-04-28 18:39:07 +00:00
|
|
|
});
|
|
|
|
});
|