小编one*_*men的帖子

仅在向主发出合并请求时运行gitlab-ci.yml

我目前在GitLabHeroku中有我的项目。我想做的是,一旦我请求与功能分支的合并请求(我们称之为crud-on-spaghetti),我想在该分支上自动运行测试(npm test基本上是使用Mocha / Chai),在测试成功后,将其crud-on-spaghettimaster,将其提交并推送至origin/master(在GitLab上是远程的),然后提交git push heroku master(基本上将其推送至存储我的应用程序的Heroku中的master分支)。我已经阅读了有关GitLab CI的几篇文章,我认为这更适合我(而不是Heroku CI,因为我没有DEV和PROD实例)。

因此,到目前为止,我手动执行此操作。这是我的.gitlab-ci.yml文件(尚未提交/推送):

stages:
  - test
  - deploy

test_for_illegal_bugs:
  stage: test
  script:
    - npm test

deploy_to_dev:
  stage: deploy
  only:
    - origin master
  script:
    - git commit
    - git push origin master
    - git pull heroku master --rebase
    - git push heroku master
Run Code Online (Sandbox Code Playgroud)

因此,我的问题是:.gitlab-ci.yml为了使所有这些“操作”(上图)自动化,我到底需要写些什么?

PS。还有另一个(理论上的)后续问题:GitLab-CI Runner是如何触发的?例如,如果我希望它在与master合并请求时触发,是否可以使用only: ...in来做到这一点.gitlab-ci.yml

heroku node.js gitlab gitlab-ci

5
推荐指数
2
解决办法
1961
查看次数

这种嵌套循环的算法复杂性

是它O(n)还是O(n*logn)下面的代码:

for(int j=n, int sum = 0; j>0 ; j--) 
    for(int k=j; k >0; k--) sum++;
Run Code Online (Sandbox Code Playgroud)

迭代列表:

j = 5: k = 5, 4, 3, 2, 1
j = 4: k = 4, 3, 2, 1,
j = 3: k = 3, 2, 1
j = 2: k = 2, 1
j = 1: k = 1
Run Code Online (Sandbox Code Playgroud)

我们总共有15次迭代.但是,如果是O(n),那么只需要5次迭代.

如果它是O(n*logn)答案将只有大约11-12迭代.

algorithm big-o time-complexity c++11

2
推荐指数
1
解决办法
98
查看次数

标签 统计

algorithm ×1

big-o ×1

c++11 ×1

gitlab ×1

gitlab-ci ×1

heroku ×1

node.js ×1

time-complexity ×1