4个提高效率的GitHub Actions技巧

新闻 前端
本文介绍了4个能帮你节省时间的 GitHub Actions,它们可以改善你的工作流。

 [[328955]]

本文介绍了4个能帮你节省时间的 GitHub Actions,它们可以改善你的工作流。

如果你将代码托管在 GitHub 上,那么你可以充分利用 GitHub Actions。借助 GitHub Actions,你可以完成代码测试和检查,无需手动运行这些任务。

https://github.com/features/actions

如果你不很清楚 GitHub Actions 是什么以及如何使用它们,我建议你先看看 阮一峰的 GitHub Actions 入门教程。

http://www.ruanyifeng.com/blog/2019/09/getting-started-with-github-actions.html

1. 利用 GitHub Actions 审计网页

这一操作集成了谷歌提供的实用网页审计工具 Lighthouse,可以检测性能、可访问性、最佳实践、搜索引擎优化和渐进式 Web 应用程序。

https://developers.google.com/web/tools/lighthouse/

4个提高效率的GitHub Actions技巧

Github Lighthouse Action

目前,该操作会打印出 5 个分数(满分 100),并上传 HTML 和 JSON 版本的报告。

在下一个版本中,该操作将允许你指定每项测试的阈值,如果不满足条件,可以有选择性地停止这个步骤。

4个提高效率的GitHub Actions技巧

Lighthouse 审计报告示例

用法

下面的工作流在 jarv.is 上运行一个 Lighthouse 审计,该步骤会在输出中显示 5 个分数,并上传结果 .html 和 .json的版本,以供下载(如上所示)。

https://jarv.is/

workflow.yml文件:

  1. name: Audit live site 
  2. on: pushjobs: 
  3.   audit: 
  4.     runs-on: ubuntu-latest 
  5.     steps: 
  6.     - name: Audit live URL 
  7.       uses: jakejarvis/lighthouse-action@master 
  8.       with: 
  9.         url: 'https://jarv.is/' 
  10.     - name: Upload results as an artifact 
  11.       uses: actions/upload-artifact@master 
  12.       with: 
  13.         name: report 
  14.         path: './report' 

2. 利用 GitHub Actions 运行 SSH 命令

该操作将通过 SSH 在你的 $HOST 上将提供的参数作为命令运行。如果你想在每次提交或推送之后在自己的私有服务器上运行命令,那么它会非常有用。

4个提高效率的GitHub Actions技巧

SSH GitHub Action

用法

要使用这个操作,只需要在.github/main.workflow文件中添加以下几行:

  1. action "Run deploy script" { 
  2.   uses = "maddox/actions/ssh@master" 
  3.   args = "/opt/deploy/run" 
  4.   secrets = [ 
  5.     "PRIVATE_KEY"
  6.     "HOST"
  7.     "USER" 
  8.   ] 

所需的参数

你所使用的参数就是你要通过 SSH 在你的服务器上运行的命令。

示例

  • args = "/opt/deploy/run"
  • args = "touch ~/.reload"

所需的私密信息

要使用这项操作,你需要提供以下私密信息:

  • PRIVATE_KEY:SSH 私钥;
  • HOST:该操作将通过 SSH 连接并运行命令的主机,如your.site.com;
  • USER: SSH 命令将其和私钥一起用于身份验证的用户。

要了解更多细节,请查看 GitHub 库。

https://github.com/maddox/actions/tree/master/ssh

3. 利用 GitHub Actions 检测密钥泄漏

将 gitleaks 作为一个 GitHub Action,用于审计 Git 提交中的秘密。如果你使用.env文件,该操作会在你无意中发布了私密信息时通知你。

https://github.com/zricethezav/gitleaks

4个提高效率的GitHub Actions技巧

Gitleaks-action

用法

  1. workflow "gitleaks my commits" { 
  2.   on = "push" 
  3.   resolves = ["gitleaks"
  4. }action "gitleaks" { 
  5.   uses = "eshork/gitleaks-action@master" 

要了解更多信息,请移步 zricethezav/gitleaks。

https://github.com/zricethezav/gitleaks

4. 利用 GitHub Action 运行 ESLint

4个提高效率的GitHub Actions技巧

Eslint Action

该操作在指定的 JavaScript 文件上执行 ESLint 代码检查工具,而不需要任何前期的操作 / 构建步骤或 Docker。

https://eslint.org/

要执行操作,本地必须运行 ESLint。它将使用与本地相同的规则。要了解更多信息,请查看 ESLint 入门指南。

https://eslint.org/docs/user-guide/getting-started#installation-and-usage

用法

将下面的任何一个例子添加到文件.github/main.workflow。

下面是一个使用该操作的示例:

  1. workflow "New workflow" { 
  2.   on = "push" 
  3.   resolves = ["ESLint"
  4. }action "ESLint" { 
  5.   uses = "stefanoeb/eslint-action@master" 

在默认情况下,它会对项目中的所有文件运行 ESLint。但是,你可以使用args 指定要检查的文件,如下所示:

  1. workflow "New workflow" { 
  2.   on = "push" 
  3.   resolves = ["ESLint"
  4. }action "ESLint" { 
  5.   uses = "stefanoeb/eslint-action@master" 
  6.   args = "index.js src/**.js" 

如果你之前没有安装必要的模块,那么该操作会自动运行yarn install 或 npm install 。

5. 小结

感谢阅读,希望本文对你有所帮助。如果你知道任何其他有用的 GitHub Actions,请告诉我们。保持好奇,快乐编码!

 

 

责任编辑:张燕妮 来源: 架构头条
相关推荐

2023-10-23 15:02:53

JavaScript

2019-09-26 16:05:18

GitGithub开源

2018-09-30 14:46:38

Linux命令技巧

2015-11-27 12:59:11

Android技巧提高效率

2019-06-25 08:42:13

Linux命令指令

2010-04-13 15:14:31

Oracle优化

2023-05-17 16:47:47

物联网智能建筑

2015-05-22 14:01:50

编程提高效率

2015-06-02 09:33:30

编程效率程序员

2014-12-12 09:52:04

JavaScript

2021-08-02 09:29:08

Vscode开发Web

2012-03-27 09:17:43

Visual Stud

2015-09-06 16:05:57

绿色数据中心效率

2021-12-17 15:03:50

Python工具代码

2013-11-18 10:31:03

Unix操作

2013-11-18 10:36:39

Unix命令

2022-11-30 15:22:02

DevOps软件开发运维

2012-07-16 00:51:36

程序员效率

2012-06-01 14:44:27

惠普台式机

2010-09-09 16:51:50

点赞
收藏

51CTO技术栈公众号