Skip to content

Commit

Permalink
fix(sfppackage): improve error message when repository URL is not par…
Browse files Browse the repository at this point in the history
…seable

This adds a skipped test that should be enabled after #137
  • Loading branch information
richard-giraud committed Nov 14, 2024
1 parent 357b118 commit 750699c
Show file tree
Hide file tree
Showing 2 changed files with 59 additions and 1 deletion.
14 changes: 13 additions & 1 deletion src/core/package/SfpPackageInquirer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,19 @@ export default class SfpPackageInquirer {
let remoteURL: gitUrlParse.GitUrl;

for (let sfpPackage of this.sfpPackages) {
let currentRemoteURL = gitUrlParse(sfpPackage.repository_url);
let currentRemoteURL: gitUrlParse.GitUrl;

try {
currentRemoteURL = gitUrlParse(sfpPackage.repository_url) as gitUrlParse.GitUrl;

Check failure on line 93 in src/core/package/SfpPackageInquirer.ts

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

src/core/package/SfpPackageInquirer.ts#L93

Unsafe assignment of an error typed value.

Check failure on line 93 in src/core/package/SfpPackageInquirer.ts

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

src/core/package/SfpPackageInquirer.ts#L93

Unsafe call of an `error` type typed value.
} catch (ex) {
if (ex instanceof Error && ex.message === 'URL parsing failed.') {
throw new Error(
`Invalid repository URL for package '${sfpPackage.package_name}': ${sfpPackage.repository_url}`
);
} else {
throw ex;
}
}

if (remoteURL == null) {
remoteURL = currentRemoteURL;
Expand Down
46 changes: 46 additions & 0 deletions tests/core/package/SfpPackageInquirer.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
import { expect } from '@jest/globals';
import SfpPackage from '../../../lib/core/package/SfpPackage';
import SfpPackageInquirer from '../../../src/core/package/SfpPackageInquirer';

describe('validateArtifactsSourceRepository', () => {
describe('Given a bad repository URL, display', () => {
it('should accept a good repository SSH URL', async () => {
const repositoryUrl = 'git@github.com:flxbl-io/sfp-test.git';

let sfpPackage: SfpPackage = new SfpPackage();
sfpPackage.package_name = 'testPackageName';
sfpPackage.repository_url = repositoryUrl;

let sfpPackageInquirer = new SfpPackageInquirer([sfpPackage]);
sfpPackageInquirer.validateArtifactsSourceRepository();
});

// TODO: re-enable once https://github.com/flxbl-io/sfp/issues/137 is fixed
it.skip.failing('should accept a good repository SSH URL with a URL-encoded space', async () => {
const repositoryUrl = 'git@github.com:flxbl-io/sfp%20test.git';

let sfpPackage: SfpPackage = new SfpPackage();
sfpPackage.package_name = 'testPackageName';
sfpPackage.repository_url = repositoryUrl;

let sfpPackageInquirer = new SfpPackageInquirer([sfpPackage]);
sfpPackageInquirer.validateArtifactsSourceRepository();
});

it('should reject a bad repository SSH URL with a helpful error message', async () => {
const repositoryUrl = 'git';

const t = () => {
let sfpPackage: SfpPackage = new SfpPackage();
sfpPackage.package_name = 'testPackageName';
sfpPackage.repository_url = repositoryUrl;

let sfpPackageInquirer = new SfpPackageInquirer([sfpPackage]);
sfpPackageInquirer.validateArtifactsSourceRepository();
};

expect(t).toThrow(Error);
expect(t).toThrow("Invalid repository URL for package 'testPackageName': git");
});
});
});

0 comments on commit 750699c

Please sign in to comment.