[英]set upstream branch tracking after moving and re-adding remote URL in simple-git
以下代码检查本地存储库是否存在,并使用simple-git同步远程存储库中的更改。 我遇到了一些JWT
令牌在 24 小时后到期的问题,通过删除并重新添加远程存储库 URL 解决了这个问题。
if (fs.existsSync(cachePath)) {
debug(`Local Path ${cachePath} Exists`);
// debug('Checking `git status` on local repo');
// Fetch
// FIXME: no upstream branch is set -> no tracking information for the current branch
// await git(cachePath).removeRemote('origin');
// await git(cachePath).addRemote('origin', gitURL);
// go into file and replace tocken
// FIXME: fatal branch 'master' doesn't exist
// execSync('git branch --set-upstream-to=origin/master master');
// await git(cachePath).branch(['--set-upstream-to=origin/master', 'master'], (err, data) => {
// if (err) throw new Error(err);
// });
// Show all branches
// debug('SHOW ALL BRANCHES');
// await git(cachePath).branch(['-a'], (err, data) => {
// if (err) throw new Error(err);
// });
/* CMDs
-------------------------------------------------- */
try {
execSync(`cd ${cachePath}`, { stdio: 'inherit' });
execSync('git remote -v', { stdio: 'inherit' });
execSync('git remote remove origin', { stdio: 'inherit' });
execSync(`git remote add origin ${gitURL}`, { stdio: 'inherit' });
execSync('git remote -v', { stdio: 'inherit' });
// execSync('git branch --set-upstream-to=origin/master master', { stdio: 'inherit' });
git(cachePath).branch(['-u', 'origin/master'], (err, data) => {
if (err) throw new Error(err);
console.log(data);
});
execSync('cd /home/ystanev/menlolab/runner', { stdio: 'inherit' });
} catch (e) {
throw new Error(e);
}
/* End of CMDs
-------------------------------------------------- */
debug('GIT PULL');
await git(cachePath)
.outputHandler(outputHandler)
.pull();
之前的操作似乎取消了上游分支跟踪,让我无法git fetch/pull
。 在 git 输出之后,我通过执行git branch --set-upstream-to=origin/master master
设置了跟踪,问题似乎已解决。
我试图通过bash
命令完成整个事情,但我不断收到错误消息:
error: the requested upstream branch 'origin/master' does not exist
与远程存储库的通信似乎存在问题,因为相同的命令在本地存储库中的bash
shell 中运行得很好。
关于可能的原因有什么建议吗?
正如@torek 在评论中提到的,我必须在设置上游之前运行git fetch
。
最终代码如下:
if (fs.existsSync(cachePath)) {
debug(`Local Path ${cachePath} Exists`);
// Fetch
await git(cachePath).removeRemote('origin');
await git(cachePath).addRemote('origin', gitURL);
await git(cachePath).fetch('origin');
await git(cachePath).branch(['-u', 'origin/master']);
debug('GIT PULL');
await git(cachePath)
.outputHandler(outputHandler)
.pull();
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.