fix: support github server url for pushing to fork (#1318)
* feat: support github server url for pushing to fork (#1315) Co-authored-by: Kevin Zhu <kevin.zhu@sap.com> * fix: code formatting * test: fix tests for getRemoteUrl Co-authored-by: MildC <kevin.xizhu@gmail.com> Co-authored-by: Kevin Zhu <kevin.zhu@sap.com>
This commit is contained in:
parent
d7db273d6c
commit
331d02c7e2
|
@ -90,11 +90,28 @@ describe('utils tests', () => {
|
||||||
})
|
})
|
||||||
|
|
||||||
test('getRemoteUrl successfully returns remote URLs', async () => {
|
test('getRemoteUrl successfully returns remote URLs', async () => {
|
||||||
const url1 = utils.getRemoteUrl('HTTPS', 'peter-evans/create-pull-request')
|
const url1 = utils.getRemoteUrl(
|
||||||
|
'HTTPS',
|
||||||
|
'github.com',
|
||||||
|
'peter-evans/create-pull-request'
|
||||||
|
)
|
||||||
expect(url1).toEqual('https://github.com/peter-evans/create-pull-request')
|
expect(url1).toEqual('https://github.com/peter-evans/create-pull-request')
|
||||||
|
|
||||||
const url2 = utils.getRemoteUrl('SSH', 'peter-evans/create-pull-request')
|
const url2 = utils.getRemoteUrl(
|
||||||
|
'SSH',
|
||||||
|
'github.com',
|
||||||
|
'peter-evans/create-pull-request'
|
||||||
|
)
|
||||||
expect(url2).toEqual('git@github.com:peter-evans/create-pull-request.git')
|
expect(url2).toEqual('git@github.com:peter-evans/create-pull-request.git')
|
||||||
|
|
||||||
|
const url3 = utils.getRemoteUrl(
|
||||||
|
'HTTPS',
|
||||||
|
'mygithubserver.com',
|
||||||
|
'peter-evans/create-pull-request'
|
||||||
|
)
|
||||||
|
expect(url3).toEqual(
|
||||||
|
'https://mygithubserver.com/peter-evans/create-pull-request'
|
||||||
|
)
|
||||||
})
|
})
|
||||||
|
|
||||||
test('secondsSinceEpoch returns the number of seconds since the Epoch', async () => {
|
test('secondsSinceEpoch returns the number of seconds since the Epoch', async () => {
|
||||||
|
|
15
dist/index.js
vendored
15
dist/index.js
vendored
|
@ -339,7 +339,7 @@ function createPullRequest(inputs) {
|
||||||
throw new Error(`Repository '${branchRepository}' is not a fork of '${baseRemote.repository}'. Unable to continue.`);
|
throw new Error(`Repository '${branchRepository}' is not a fork of '${baseRemote.repository}'. Unable to continue.`);
|
||||||
}
|
}
|
||||||
// Add a remote for the fork
|
// Add a remote for the fork
|
||||||
const remoteUrl = utils.getRemoteUrl(baseRemote.protocol, branchRepository);
|
const remoteUrl = utils.getRemoteUrl(baseRemote.protocol, baseRemote.hostname, branchRepository);
|
||||||
yield git.exec(['remote', 'add', 'fork', remoteUrl]);
|
yield git.exec(['remote', 'add', 'fork', remoteUrl]);
|
||||||
}
|
}
|
||||||
core.endGroup();
|
core.endGroup();
|
||||||
|
@ -1247,11 +1247,13 @@ function getRemoteDetail(remoteUrl) {
|
||||||
if (!githubServerMatch) {
|
if (!githubServerMatch) {
|
||||||
throw new Error('Could not parse GitHub Server name');
|
throw new Error('Could not parse GitHub Server name');
|
||||||
}
|
}
|
||||||
const httpsUrlPattern = new RegExp('^https?://.*@?' + githubServerMatch[1] + '/(.+/.+?)(\\.git)?$', 'i');
|
const hostname = githubServerMatch[1];
|
||||||
const sshUrlPattern = new RegExp('^git@' + githubServerMatch[1] + ':(.+/.+)\\.git$', 'i');
|
const httpsUrlPattern = new RegExp('^https?://.*@?' + hostname + '/(.+/.+?)(\\.git)?$', 'i');
|
||||||
|
const sshUrlPattern = new RegExp('^git@' + hostname + ':(.+/.+)\\.git$', 'i');
|
||||||
const httpsMatch = remoteUrl.match(httpsUrlPattern);
|
const httpsMatch = remoteUrl.match(httpsUrlPattern);
|
||||||
if (httpsMatch) {
|
if (httpsMatch) {
|
||||||
return {
|
return {
|
||||||
|
hostname,
|
||||||
protocol: 'HTTPS',
|
protocol: 'HTTPS',
|
||||||
repository: httpsMatch[1]
|
repository: httpsMatch[1]
|
||||||
};
|
};
|
||||||
|
@ -1259,6 +1261,7 @@ function getRemoteDetail(remoteUrl) {
|
||||||
const sshMatch = remoteUrl.match(sshUrlPattern);
|
const sshMatch = remoteUrl.match(sshUrlPattern);
|
||||||
if (sshMatch) {
|
if (sshMatch) {
|
||||||
return {
|
return {
|
||||||
|
hostname,
|
||||||
protocol: 'SSH',
|
protocol: 'SSH',
|
||||||
repository: sshMatch[1]
|
repository: sshMatch[1]
|
||||||
};
|
};
|
||||||
|
@ -1266,10 +1269,10 @@ function getRemoteDetail(remoteUrl) {
|
||||||
throw new Error(`The format of '${remoteUrl}' is not a valid GitHub repository URL`);
|
throw new Error(`The format of '${remoteUrl}' is not a valid GitHub repository URL`);
|
||||||
}
|
}
|
||||||
exports.getRemoteDetail = getRemoteDetail;
|
exports.getRemoteDetail = getRemoteDetail;
|
||||||
function getRemoteUrl(protocol, repository) {
|
function getRemoteUrl(protocol, hostname, repository) {
|
||||||
return protocol == 'HTTPS'
|
return protocol == 'HTTPS'
|
||||||
? `https://github.com/${repository}`
|
? `https://${hostname}/${repository}`
|
||||||
: `git@github.com:${repository}.git`;
|
: `git@${hostname}:${repository}.git`;
|
||||||
}
|
}
|
||||||
exports.getRemoteUrl = getRemoteUrl;
|
exports.getRemoteUrl = getRemoteUrl;
|
||||||
function secondsSinceEpoch() {
|
function secondsSinceEpoch() {
|
||||||
|
|
|
@ -74,6 +74,7 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
|
||||||
// Add a remote for the fork
|
// Add a remote for the fork
|
||||||
const remoteUrl = utils.getRemoteUrl(
|
const remoteUrl = utils.getRemoteUrl(
|
||||||
baseRemote.protocol,
|
baseRemote.protocol,
|
||||||
|
baseRemote.hostname,
|
||||||
branchRepository
|
branchRepository
|
||||||
)
|
)
|
||||||
await git.exec(['remote', 'add', 'fork', remoteUrl])
|
await git.exec(['remote', 'add', 'fork', remoteUrl])
|
||||||
|
|
22
src/utils.ts
22
src/utils.ts
|
@ -32,6 +32,7 @@ export function getRepoPath(relativePath?: string): string {
|
||||||
}
|
}
|
||||||
|
|
||||||
interface RemoteDetail {
|
interface RemoteDetail {
|
||||||
|
hostname: string
|
||||||
protocol: string
|
protocol: string
|
||||||
repository: string
|
repository: string
|
||||||
}
|
}
|
||||||
|
@ -46,18 +47,18 @@ export function getRemoteDetail(remoteUrl: string): RemoteDetail {
|
||||||
throw new Error('Could not parse GitHub Server name')
|
throw new Error('Could not parse GitHub Server name')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const hostname = githubServerMatch[1]
|
||||||
|
|
||||||
const httpsUrlPattern = new RegExp(
|
const httpsUrlPattern = new RegExp(
|
||||||
'^https?://.*@?' + githubServerMatch[1] + '/(.+/.+?)(\\.git)?$',
|
'^https?://.*@?' + hostname + '/(.+/.+?)(\\.git)?$',
|
||||||
'i'
|
|
||||||
)
|
|
||||||
const sshUrlPattern = new RegExp(
|
|
||||||
'^git@' + githubServerMatch[1] + ':(.+/.+)\\.git$',
|
|
||||||
'i'
|
'i'
|
||||||
)
|
)
|
||||||
|
const sshUrlPattern = new RegExp('^git@' + hostname + ':(.+/.+)\\.git$', 'i')
|
||||||
|
|
||||||
const httpsMatch = remoteUrl.match(httpsUrlPattern)
|
const httpsMatch = remoteUrl.match(httpsUrlPattern)
|
||||||
if (httpsMatch) {
|
if (httpsMatch) {
|
||||||
return {
|
return {
|
||||||
|
hostname,
|
||||||
protocol: 'HTTPS',
|
protocol: 'HTTPS',
|
||||||
repository: httpsMatch[1]
|
repository: httpsMatch[1]
|
||||||
}
|
}
|
||||||
|
@ -66,6 +67,7 @@ export function getRemoteDetail(remoteUrl: string): RemoteDetail {
|
||||||
const sshMatch = remoteUrl.match(sshUrlPattern)
|
const sshMatch = remoteUrl.match(sshUrlPattern)
|
||||||
if (sshMatch) {
|
if (sshMatch) {
|
||||||
return {
|
return {
|
||||||
|
hostname,
|
||||||
protocol: 'SSH',
|
protocol: 'SSH',
|
||||||
repository: sshMatch[1]
|
repository: sshMatch[1]
|
||||||
}
|
}
|
||||||
|
@ -76,10 +78,14 @@ export function getRemoteDetail(remoteUrl: string): RemoteDetail {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getRemoteUrl(protocol: string, repository: string): string {
|
export function getRemoteUrl(
|
||||||
|
protocol: string,
|
||||||
|
hostname: string,
|
||||||
|
repository: string
|
||||||
|
): string {
|
||||||
return protocol == 'HTTPS'
|
return protocol == 'HTTPS'
|
||||||
? `https://github.com/${repository}`
|
? `https://${hostname}/${repository}`
|
||||||
: `git@github.com:${repository}.git`
|
: `git@${hostname}:${repository}.git`
|
||||||
}
|
}
|
||||||
|
|
||||||
export function secondsSinceEpoch(): number {
|
export function secondsSinceEpoch(): number {
|
||||||
|
|
Loading…
Reference in a new issue