- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含 git 子模块的项目,它们都托管在 GitHub 上。
子模块源作为项目的一部分构建,子模块中的更改可能会影响包含的项目。
我的目标是确保子模块不会破坏包含的项目。
为此,我正在尝试创建一个 GitHub 操作在子模块存储库上,它在推/pull 时执行以下操作:
标准Checkout v2 action 不支持这样的工作流。
相反,我根据 $GITHUB_SHA
克隆并检查子模块,如下所示:
- name: Checkout project
run: git clone <Project>
- name: Update submodules
run: git submodule update --init --recursive
- name: Checkout submodule
working-directory: ./<submodule dir>
run: |
git fetch
git checkout $GITHUB_SHA
- name: Build
run : make
这适用于推送,但不适用于 pull 请求。
在 PR 上我得到这样的东西:
fatal: reference is not a tree: 48fd1d918a25e7544969d13949b1d436f525412c
在 PR 的情况下,$GITHUB_SHA
提供的 SHA 根本找不到。
$GITHUB_SHA
在 PR 的情况下是错误的?如果是 PR,它代表什么?如果不清楚 - 有问题的 PR 是在 子模块 的 repo 上,而不是在主(包含)项目 repo 上。
该操作在子模块 repo 上运行,并检查包含模块和子模块。
这个问题与以下事实有关:PR(子模块)的 $GITHUB_SHA
似乎并不代表对子模块的提交,尽管我预计它会。
我又做了一次尝试:
尝试将此作为 checkout 子模块“运行”步骤:
git fetch ${{ github.event.repository.git_url }}
git fetch ${{ github.event.pull_request.head.repo.clone_url }}
git checkout ${{ github.sha }} || git checkout ${{ github.event.pull_request.head.sha }}
在 PR 上,两个 SHA 的 checkout 仍然失败:
fatal: reference is not a tree
因此,从 PR 来自的原始 repo 中获取 - 没有帮助。pull_request.head.sha
看起来是正确的(这次是正确的 SHA),但是 git checkout
甚至失败了!不知道为什么。
最终我找到了解决方法!
这是“checkout 子模块”运行步骤:
run: |
git fetch --force ${{ github.event.repository.git_url }} "+refs/heads/*:refs/remotes/origin/*"
git fetch --force ${{ github.event.repository.git_url }} "+refs/pull/*/head:refs/remotes/origin/pr/*"
git checkout ${{ github.sha }} || git checkout ${{ github.event.pull_request.head.sha }}
所以我正在做的是:
git_url
获取头部git_url
获取所有 PR github.sha
。这适用于推送但不适用于 PRgithub.event.pull_request.head.sha
。这适用于 PR 但不适用于推送....然而,同样的问题仍然存在——
github.sha
在 PR 的情况下是错误的?如果是 PR,它代表什么?github.sha
和 github.event.pull_request。 head.sha
?最佳答案
显然,在 PR 的情况下,github.sha
(或 $GITHUB_SHA
)表示生成的提交的 SHA,该提交是通过将基础 merge 到头部,而不是基础更改的 SHA 提交本身。
要获取它,我需要获取 refs/pull/*/merge
而不是 refs/pull/*/head
。
现在这个运行步骤更有意义了:
git fetch --force ${{ github.event.repository.git_url }} "+refs/heads/*:refs/remotes/origin/*"
git fetch --force ${{ github.event.repository.git_url }} "+refs/pull/*/merge:refs/remotes/origin/pr/*"
git checkout ${{ github.sha }}
第一次获取将获取头部,用于推送操作。第二个将获取 PR 的 merge 提交。
两者都由 github.sha
表示。
关于GitHub 操作将 repo 作为 git 子模块 checkout ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63795736/
我最近在我的机器上安装了 cx_Oracle 模块,以便连接到远程 Oracle 数据库服务器。 (我身边没有 Oracle 客户端)。 Python:版本 2.7 x86 Oracle:版本 11.
我想从 python timeit 模块检查打印以下内容需要多少时间,如何打印, import timeit x = [x for x in range(10000)] timeit.timeit("
我盯着 vs 代码编辑器上的 java 脚本编码,当我尝试将外部模块包含到我的项目中时,代码编辑器提出了这样的建议 -->(文件是 CommonJS 模块;它可能会转换为 ES6 模块。 )..有什么
我有一个 Node 应用程序,我想在标准 ES6 模块格式中使用(即 "type": "module" in the package.json ,并始终使用 import 和 export)而不转译为
我正在学习将 BlueprintJS 合并到我的 React 网络应用程序中,并且在加载某些 CSS 模块时遇到了很多麻烦。 我已经安装了 npm install @blueprintjs/core和
我需要重构一堆具有这样的调用的文件 define(['module1','module2','module3' etc...], function(a, b, c etc...) { //bun
我是 Angular 的新手,正在学习各种教程(Codecademy、thinkster.io 等),并且已经看到了声明应用程序容器的两种方法。首先: var app = angular.module
我正在尝试将 OUnit 与 OCaml 一起使用。 单元代码源码(unit.ml)如下: open OUnit let empty_list = [] let list_a = [1;2;3] le
我在 Angular 1.x 应用程序中使用 webpack 和 ES6 模块。在我设置的 webpack.config 中: resolve: { alias: { 'angular':
internal/modules/cjs/loader.js:750 return process.dlopen(module, path.toNamespacedPath(filename));
在本教程中,您将借助示例了解 JavaScript 中的模块。 随着我们的程序变得越来越大,它可能包含许多行代码。您可以使用模块根据功能将代码分隔在单独的文件中,而不是将所有内容都放在一个文件
我想知道是否可以将此代码更改为仅调用 MyModule.RED 而不是 MyModule.COLORS.RED。我尝试将 mod 设置为变量来存储颜色,但似乎不起作用。难道是我方法不对? (funct
我有以下代码。它是一个 JavaScript 模块。 (function() { // Object var Cahootsy; Cahootsy = { hello:
关闭。这个问题是 opinion-based 。它目前不接受答案。 想要改进这个问题?更新问题,以便 editing this post 可以用事实和引文来回答它。 关闭 2 年前。 Improve
从用户的角度来看,一个模块能够通过 require 加载并返回一个 table,模块导出的接口都被定义在此 table 中(此 table 被作为一个 namespace)。所有的标准库都是模块。标
Ruby的模块非常类似类,除了: 模块不可以有实体 模块不可以有子类 模块由module...end定义. 实际上...模块的'模块类'是'类的类'这个类的父类.搞懂了吗?不懂?让我们继续看
我有一个脚本,它从 CLI 获取 3 个输入变量并将其分别插入到 3 个变量: GetOptions("old_path=s" => \$old_path, "var=s" =
我有一个简单的 python 包,其目录结构如下: wibble | |-----foo | |----ping.py | |-----bar | |----pong.py 简单的
这种语法会非常有用——这不起作用有什么原因吗?谢谢! module Foo = { let bar: string = "bar" }; let bar = Foo.bar; /* works *
我想运行一个命令: - name: install pip shell: "python {"changed": true, "cmd": "python <(curl https://boot
我是一名优秀的程序员,十分优秀!