shipit-engine 0.31.0 → 0.32.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (290) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +4 -2
  3. data/Rakefile +4 -2
  4. data/app/assets/stylesheets/_pages/_stacks.scss +0 -3
  5. data/app/assets/stylesheets/merge_status.scss +0 -3
  6. data/app/controllers/concerns/shipit/active_model_serializers_patch.rb +1 -0
  7. data/app/controllers/concerns/shipit/api/cacheable.rb +1 -0
  8. data/app/controllers/concerns/shipit/api/paginable.rb +3 -2
  9. data/app/controllers/concerns/shipit/api/rendering.rb +5 -4
  10. data/app/controllers/concerns/shipit/authentication.rb +3 -2
  11. data/app/controllers/concerns/shipit/pagination.rb +2 -1
  12. data/app/controllers/shipit/api/base_controller.rb +11 -6
  13. data/app/controllers/shipit/api/ccmenu_controller.rb +2 -1
  14. data/app/controllers/shipit/api/commits_controller.rb +2 -1
  15. data/app/controllers/shipit/api/deploys_controller.rb +4 -3
  16. data/app/controllers/shipit/api/hooks_controller.rb +6 -5
  17. data/app/controllers/shipit/api/locks_controller.rb +5 -4
  18. data/app/controllers/shipit/api/outputs_controller.rb +2 -1
  19. data/app/controllers/shipit/api/pull_requests_controller.rb +7 -6
  20. data/app/controllers/shipit/api/release_statuses_controller.rb +3 -2
  21. data/app/controllers/shipit/api/rollbacks_controller.rb +33 -0
  22. data/app/controllers/shipit/api/stacks_controller.rb +18 -5
  23. data/app/controllers/shipit/api/tasks_controller.rb +6 -5
  24. data/app/controllers/shipit/api_clients_controller.rb +4 -3
  25. data/app/controllers/shipit/ccmenu_url_controller.rb +4 -3
  26. data/app/controllers/shipit/commit_checks_controller.rb +2 -1
  27. data/app/controllers/shipit/commits_controller.rb +2 -1
  28. data/app/controllers/shipit/deploys_controller.rb +3 -2
  29. data/app/controllers/shipit/github_authentication_controller.rb +4 -3
  30. data/app/controllers/shipit/merge_status_controller.rb +17 -16
  31. data/app/controllers/shipit/pull_requests_controller.rb +3 -2
  32. data/app/controllers/shipit/release_statuses_controller.rb +3 -2
  33. data/app/controllers/shipit/rollbacks_controller.rb +3 -2
  34. data/app/controllers/shipit/shipit_controller.rb +2 -1
  35. data/app/controllers/shipit/stacks_controller.rb +22 -7
  36. data/app/controllers/shipit/status_controller.rb +2 -1
  37. data/app/controllers/shipit/tasks_controller.rb +6 -5
  38. data/app/controllers/shipit/webhooks_controller.rb +3 -2
  39. data/app/helpers/shipit/chunks_helper.rb +1 -0
  40. data/app/helpers/shipit/deploys_helper.rb +4 -3
  41. data/app/helpers/shipit/github_url_helper.rb +1 -0
  42. data/app/helpers/shipit/merge_status_helper.rb +1 -0
  43. data/app/helpers/shipit/shipit_helper.rb +1 -0
  44. data/app/helpers/shipit/stacks_helper.rb +1 -0
  45. data/app/helpers/shipit/tasks_helper.rb +1 -0
  46. data/app/jobs/shipit/background_job.rb +4 -0
  47. data/app/jobs/shipit/background_job/unique.rb +1 -0
  48. data/app/jobs/shipit/cache_deploy_spec_job.rb +1 -0
  49. data/app/jobs/shipit/chunk_rollup_job.rb +4 -0
  50. data/app/jobs/shipit/clear_git_cache_job.rb +1 -0
  51. data/app/jobs/shipit/continuous_delivery_job.rb +2 -1
  52. data/app/jobs/shipit/create_on_github_job.rb +6 -1
  53. data/app/jobs/shipit/create_release_statuses_job.rb +1 -0
  54. data/app/jobs/shipit/deferred_touch_job.rb +4 -0
  55. data/app/jobs/shipit/deliver_hook_job.rb +1 -0
  56. data/app/jobs/shipit/destroy_job.rb +1 -0
  57. data/app/jobs/shipit/destroy_stack_job.rb +1 -0
  58. data/app/jobs/shipit/emit_event_job.rb +2 -1
  59. data/app/jobs/shipit/fetch_commit_stats_job.rb +1 -0
  60. data/app/jobs/shipit/fetch_deployed_revision_job.rb +1 -0
  61. data/app/jobs/shipit/github_sync_job.rb +2 -1
  62. data/app/jobs/shipit/mark_deploy_healthy_job.rb +1 -0
  63. data/app/jobs/shipit/merge_pull_requests_job.rb +1 -0
  64. data/app/jobs/shipit/perform_commit_checks_job.rb +1 -0
  65. data/app/jobs/shipit/perform_task_job.rb +12 -5
  66. data/app/jobs/shipit/purge_old_deliveries_job.rb +1 -0
  67. data/app/jobs/shipit/reap_dead_tasks_job.rb +21 -0
  68. data/app/jobs/shipit/refresh_check_runs_job.rb +1 -0
  69. data/app/jobs/shipit/refresh_github_user_job.rb +1 -0
  70. data/app/jobs/shipit/refresh_pull_request_job.rb +1 -0
  71. data/app/jobs/shipit/refresh_statuses_job.rb +1 -0
  72. data/app/jobs/shipit/setup_github_hook_job.rb +1 -0
  73. data/app/jobs/shipit/update_estimated_deploy_duration_job.rb +1 -0
  74. data/app/jobs/shipit/update_github_last_deployed_ref_job.rb +4 -3
  75. data/app/models/concerns/shipit/deferred_touch.rb +4 -3
  76. data/app/models/shipit/anonymous_user.rb +5 -0
  77. data/app/models/shipit/api_client.rb +3 -2
  78. data/app/models/shipit/application_record.rb +2 -1
  79. data/app/models/shipit/check_run.rb +4 -3
  80. data/app/models/shipit/command_line_user.rb +1 -0
  81. data/app/models/shipit/commit.rb +11 -4
  82. data/app/models/shipit/commit_checks.rb +1 -0
  83. data/app/models/shipit/commit_deployment.rb +3 -2
  84. data/app/models/shipit/commit_deployment_status.rb +2 -1
  85. data/app/models/shipit/commit_message.rb +1 -0
  86. data/app/models/shipit/delivery.rb +4 -3
  87. data/app/models/shipit/deploy.rb +6 -17
  88. data/app/models/shipit/deploy_spec.rb +22 -3
  89. data/app/models/shipit/deploy_spec/bundler_discovery.rb +1 -0
  90. data/app/models/shipit/deploy_spec/capistrano_discovery.rb +1 -0
  91. data/app/models/shipit/deploy_spec/file_system.rb +10 -3
  92. data/app/models/shipit/deploy_spec/kubernetes_discovery.rb +1 -0
  93. data/app/models/shipit/deploy_spec/lerna_discovery.rb +1 -0
  94. data/app/models/shipit/deploy_spec/npm_discovery.rb +5 -4
  95. data/app/models/shipit/deploy_spec/pypi_discovery.rb +1 -0
  96. data/app/models/shipit/deploy_spec/rubygems_discovery.rb +1 -0
  97. data/app/models/shipit/deploy_stats.rb +2 -1
  98. data/app/models/shipit/duration.rb +3 -2
  99. data/app/models/shipit/ephemeral_commit_checks.rb +1 -0
  100. data/app/models/shipit/github_hook.rb +2 -1
  101. data/app/models/shipit/github_status.rb +2 -1
  102. data/app/models/shipit/hook.rb +6 -5
  103. data/app/models/shipit/membership.rb +3 -2
  104. data/app/models/shipit/output_chunk.rb +7 -2
  105. data/app/models/shipit/pull_request.rb +6 -5
  106. data/app/models/shipit/record.rb +18 -0
  107. data/app/models/shipit/release_status.rb +3 -2
  108. data/app/models/shipit/repository.rb +10 -5
  109. data/app/models/shipit/rollback.rb +1 -0
  110. data/app/models/shipit/stack.rb +50 -16
  111. data/app/models/shipit/status.rb +3 -2
  112. data/app/models/shipit/status/common.rb +7 -6
  113. data/app/models/shipit/status/group.rb +1 -0
  114. data/app/models/shipit/status/missing.rb +2 -1
  115. data/app/models/shipit/status/unknown.rb +2 -1
  116. data/app/models/shipit/task.rb +38 -5
  117. data/app/models/shipit/task_definition.rb +1 -0
  118. data/app/models/shipit/team.rb +2 -1
  119. data/app/models/shipit/undeployed_commit.rb +1 -0
  120. data/app/models/shipit/unlimited_api_client.rb +1 -0
  121. data/app/models/shipit/user.rb +10 -8
  122. data/app/models/shipit/variable_definition.rb +1 -0
  123. data/app/models/shipit/webhooks.rb +1 -0
  124. data/app/models/shipit/webhooks/handlers/check_suite_handler.rb +1 -0
  125. data/app/models/shipit/webhooks/handlers/handler.rb +1 -0
  126. data/app/models/shipit/webhooks/handlers/membership_handler.rb +1 -0
  127. data/app/models/shipit/webhooks/handlers/push_handler.rb +1 -0
  128. data/app/models/shipit/webhooks/handlers/status_handler.rb +1 -0
  129. data/app/serializers/concerns/shipit/conditional_attributes.rb +1 -0
  130. data/app/serializers/shipit/anonymous_user_serializer.rb +1 -0
  131. data/app/serializers/shipit/command_line_user_serializer.rb +1 -0
  132. data/app/serializers/shipit/commit_serializer.rb +1 -0
  133. data/app/serializers/shipit/deploy_serializer.rb +2 -1
  134. data/app/serializers/shipit/hook_serializer.rb +1 -0
  135. data/app/serializers/shipit/pull_request_serializer.rb +1 -0
  136. data/app/serializers/shipit/rollback_serializer.rb +1 -0
  137. data/app/serializers/shipit/short_commit_serializer.rb +1 -0
  138. data/app/serializers/shipit/stack_serializer.rb +1 -0
  139. data/app/serializers/shipit/tail_task_serializer.rb +1 -0
  140. data/app/serializers/shipit/task_serializer.rb +2 -17
  141. data/app/serializers/shipit/user_serializer.rb +6 -1
  142. data/app/validators/ascii_only_validator.rb +1 -0
  143. data/app/validators/subset_validator.rb +1 -0
  144. data/app/views/layouts/shipit.html.erb +1 -1
  145. data/app/views/shipit/_variables.html.erb +1 -1
  146. data/app/views/shipit/ccmenu/project.xml.builder +2 -1
  147. data/app/views/shipit/deploys/show.html.erb +2 -2
  148. data/app/views/shipit/stacks/_header.html.erb +3 -0
  149. data/app/views/shipit/stacks/all_tasks.html.erb +28 -0
  150. data/app/views/shipit/stacks/index.html.erb +1 -1
  151. data/app/views/shipit/tasks/show.html.erb +1 -1
  152. data/config/initializers/inflections.rb +2 -1
  153. data/config/locales/en.yml +3 -3
  154. data/config/routes.rb +10 -2
  155. data/db/migrate/20200226211925_add_index_to_tasks_status.rb +5 -0
  156. data/db/migrate/20200427135152_add_pull_request_head_sha_to_commit.rb +5 -0
  157. data/db/migrate/20200615181558_add_rollback_once_aborted_to.rb +5 -0
  158. data/lib/shipit.rb +12 -2
  159. data/lib/shipit/cast_value.rb +1 -0
  160. data/lib/shipit/command.rb +13 -12
  161. data/lib/shipit/commands.rb +5 -4
  162. data/lib/shipit/csv_serializer.rb +1 -0
  163. data/lib/shipit/deploy_commands.rb +1 -0
  164. data/lib/shipit/engine.rb +7 -2
  165. data/lib/shipit/environment_variables.rb +2 -1
  166. data/lib/shipit/first_parent_commits_iterator.rb +1 -0
  167. data/lib/shipit/flock.rb +1 -0
  168. data/lib/shipit/github_app.rb +7 -6
  169. data/lib/shipit/github_http_cache_middleware.rb +1 -0
  170. data/lib/shipit/null_serializer.rb +1 -0
  171. data/lib/shipit/octokit_check_runs.rb +3 -2
  172. data/lib/shipit/octokit_iterator.rb +3 -2
  173. data/lib/shipit/paginator.rb +3 -2
  174. data/lib/shipit/rollback_commands.rb +1 -0
  175. data/lib/shipit/same_site_cookie_middleware.rb +29 -0
  176. data/lib/shipit/simple_message_verifier.rb +1 -0
  177. data/lib/shipit/stack_commands.rb +3 -2
  178. data/lib/shipit/stat.rb +1 -0
  179. data/lib/shipit/task_commands.rb +2 -0
  180. data/lib/shipit/version.rb +2 -1
  181. data/lib/snippets/release-gem +5 -1
  182. data/lib/tasks/cron.rake +2 -0
  183. data/lib/tasks/dev.rake +3 -2
  184. data/lib/tasks/shipit.rake +15 -14
  185. data/lib/tasks/teams.rake +1 -0
  186. data/test/controllers/api/base_controller_test.rb +3 -2
  187. data/test/controllers/api/ccmenu_controller_test.rb +8 -7
  188. data/test/controllers/api/commits_controller_test.rb +3 -2
  189. data/test/controllers/api/deploys_controller_test.rb +15 -14
  190. data/test/controllers/api/hooks_controller_test.rb +8 -7
  191. data/test/controllers/api/locks_controller_test.rb +7 -6
  192. data/test/controllers/api/outputs_controller_test.rb +2 -1
  193. data/test/controllers/api/pull_requests_controller_test.rb +8 -7
  194. data/test/controllers/api/release_statuses_controller_test.rb +2 -1
  195. data/test/controllers/api/rollback_controller_test.rb +113 -0
  196. data/test/controllers/api/stacks_controller_test.rb +30 -9
  197. data/test/controllers/api/tasks_controller_test.rb +13 -12
  198. data/test/controllers/api_clients_controller_test.rb +5 -4
  199. data/test/controllers/ccmenu_controller_test.rb +4 -3
  200. data/test/controllers/commit_checks_controller_test.rb +4 -3
  201. data/test/controllers/commits_controller_test.rb +3 -2
  202. data/test/controllers/deploys_controller_test.rb +32 -21
  203. data/test/controllers/github_authentication_controller_test.rb +1 -0
  204. data/test/controllers/merge_status_controller_test.rb +7 -6
  205. data/test/controllers/pull_requests_controller_test.rb +4 -3
  206. data/test/controllers/release_statuses_controller_test.rb +3 -2
  207. data/test/controllers/rollbacks_controller_test.rb +9 -8
  208. data/test/controllers/stacks_controller_test.rb +33 -19
  209. data/test/controllers/status_controller_test.rb +1 -0
  210. data/test/controllers/tasks_controller_test.rb +19 -18
  211. data/test/controllers/webhooks_controller_test.rb +11 -10
  212. data/test/dummy/config/environments/development.rb +2 -0
  213. data/test/dummy/config/environments/test.rb +2 -0
  214. data/test/dummy/db/schema.rb +4 -1
  215. data/test/fixtures/shipit/commits.yml +15 -0
  216. data/test/fixtures/shipit/repositories.yml +4 -0
  217. data/test/fixtures/shipit/stacks.yml +90 -14
  218. data/test/fixtures/timeout +2 -1
  219. data/test/helpers/api_helper.rb +1 -0
  220. data/test/helpers/fixture_aliases_helper.rb +1 -0
  221. data/test/helpers/hooks_helper.rb +2 -1
  222. data/test/helpers/json_helper.rb +15 -11
  223. data/test/helpers/links_helper.rb +4 -3
  224. data/test/helpers/payloads_helper.rb +1 -0
  225. data/test/helpers/queries_helper.rb +3 -2
  226. data/test/jobs/cache_deploy_spec_job_test.rb +2 -1
  227. data/test/jobs/chunk_rollup_job_test.rb +1 -0
  228. data/test/jobs/deliver_hook_job_test.rb +1 -0
  229. data/test/jobs/destroy_stack_job_test.rb +1 -0
  230. data/test/jobs/emit_event_job_test.rb +2 -1
  231. data/test/jobs/fetch_commit_stats_job_test.rb +1 -0
  232. data/test/jobs/fetch_deployed_revision_job_test.rb +1 -0
  233. data/test/jobs/github_sync_job_test.rb +1 -0
  234. data/test/jobs/mark_deploy_healthy_job_test.rb +1 -0
  235. data/test/jobs/merge_pull_requests_job_test.rb +1 -0
  236. data/test/jobs/perform_task_job_test.rb +4 -3
  237. data/test/jobs/purge_old_deliveries_job_test.rb +1 -0
  238. data/test/jobs/reap_dead_tasks_job_test.rb +68 -0
  239. data/test/jobs/refresh_github_user_job_test.rb +1 -0
  240. data/test/jobs/refresh_status_job_test.rb +1 -0
  241. data/test/jobs/unique_job_test.rb +1 -0
  242. data/test/jobs/update_github_last_deployed_ref_job_test.rb +1 -0
  243. data/test/middleware/same_site_cookie_middleware_test.rb +52 -0
  244. data/test/models/api_client_test.rb +1 -0
  245. data/test/models/commit_checks_test.rb +1 -0
  246. data/test/models/commit_deployment_status_test.rb +1 -0
  247. data/test/models/commit_deployment_test.rb +2 -1
  248. data/test/models/commits_test.rb +72 -6
  249. data/test/models/delivery_test.rb +2 -1
  250. data/test/models/deploy_spec_test.rb +47 -42
  251. data/test/models/deploy_stats_test.rb +1 -0
  252. data/test/models/deploys_test.rb +31 -22
  253. data/test/models/duration_test.rb +1 -0
  254. data/test/models/github_hook_test.rb +1 -0
  255. data/test/models/hook_test.rb +18 -10
  256. data/test/models/membership_test.rb +1 -0
  257. data/test/models/output_chunk_test.rb +1 -0
  258. data/test/models/pull_request_test.rb +4 -3
  259. data/test/models/release_statuses_test.rb +1 -0
  260. data/test/models/rollbacks_test.rb +1 -0
  261. data/test/models/shipit/check_run_test.rb +1 -0
  262. data/test/models/shipit/repository_test.rb +1 -0
  263. data/test/models/shipit/wehbooks/handlers_test.rb +1 -0
  264. data/test/models/stacks_test.rb +30 -8
  265. data/test/models/status/group_test.rb +1 -0
  266. data/test/models/status/missing_test.rb +1 -0
  267. data/test/models/status_test.rb +1 -0
  268. data/test/models/task_definitions_test.rb +9 -8
  269. data/test/models/tasks_test.rb +18 -1
  270. data/test/models/team_test.rb +4 -2
  271. data/test/models/undeployed_commits_test.rb +1 -0
  272. data/test/models/users_test.rb +13 -5
  273. data/test/test_command_integration.rb +3 -2
  274. data/test/test_helper.rb +34 -31
  275. data/test/unit/anonymous_user_serializer_test.rb +14 -0
  276. data/test/unit/command_test.rb +8 -7
  277. data/test/unit/commands_test.rb +1 -0
  278. data/test/unit/commit_serializer_test.rb +16 -0
  279. data/test/unit/csv_serializer_test.rb +3 -2
  280. data/test/unit/deploy_commands_test.rb +5 -4
  281. data/test/unit/deploy_serializer_test.rb +17 -0
  282. data/test/unit/environment_variables_test.rb +5 -4
  283. data/test/unit/github_app_test.rb +1 -0
  284. data/test/unit/github_url_helper_test.rb +1 -0
  285. data/test/unit/rollback_commands_test.rb +2 -1
  286. data/test/unit/shipit_helper_test.rb +17 -0
  287. data/test/unit/shipit_test.rb +1 -0
  288. data/test/unit/user_serializer_test.rb +14 -0
  289. data/test/unit/variable_definition_test.rb +1 -0
  290. metadata +155 -130
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  require 'test_helper'
2
3
 
3
4
  module Shipit
@@ -54,14 +55,14 @@ module Shipit
54
55
 
55
56
  test ":state with a unexisting commit respond with 200 OK" do
56
57
  request.headers['X-Github-Event'] = 'status'
57
- params = {'sha' => 'notarealcommit', 'state' => 'pending', 'branches' => [{'name' => 'master'}]}.to_json
58
+ params = { 'sha' => 'notarealcommit', 'state' => 'pending', 'branches' => [{ 'name' => 'master' }] }.to_json
58
59
  post :create, body: params, as: :json
59
60
  assert_response :ok
60
61
  end
61
62
 
62
63
  test ":state in an untracked branche bails out" do
63
64
  request.headers['X-Github-Event'] = 'status'
64
- params = {'sha' => 'notarealcommit', 'state' => 'pending', 'branches' => []}.to_json
65
+ params = { 'sha' => 'notarealcommit', 'state' => 'pending', 'branches' => [] }.to_json
65
66
  post :create, body: params, as: :json
66
67
  assert_response :ok
67
68
  end
@@ -79,7 +80,7 @@ module Shipit
79
80
  @request.headers['X-Github-Event'] = 'ping'
80
81
 
81
82
  assert_no_enqueued_jobs do
82
- post :create, body: {zen: 'Git is beautiful'}.to_json, as: :json
83
+ post :create, body: { zen: 'Git is beautiful' }.to_json, as: :json
83
84
  assert_response :ok
84
85
  end
85
86
  end
@@ -87,7 +88,7 @@ module Shipit
87
88
  test "verifies webhook signature" do
88
89
  commit = shipit_commits(:first)
89
90
 
90
- payload = {"sha" => commit.sha, "state" => "pending", "target_url" => "https://ci.example.com/1000/output"}.to_json
91
+ payload = { "sha" => commit.sha, "state" => "pending", "target_url" => "https://ci.example.com/1000/output" }.to_json
91
92
  signature = 'sha1=4848deb1c9642cd938e8caa578d201ca359a8249'
92
93
 
93
94
  @request.headers['X-Github-Event'] = 'push'
@@ -116,7 +117,7 @@ module Shipit
116
117
  @request.headers['X-Github-Event'] = 'membership'
117
118
  Shipit.github.api.expects(:user).with('george').returns(george)
118
119
  assert_difference -> { User.count }, 1 do
119
- post :create, body: membership_params.merge(member: {login: 'george'}).to_json, as: :json
120
+ post :create, body: membership_params.merge(member: { login: 'george' }).to_json, as: :json
120
121
  assert_response :ok
121
122
  end
122
123
  end
@@ -132,7 +133,7 @@ module Shipit
132
133
  test ":membership can append an user membership" do
133
134
  @request.headers['X-Github-Event'] = 'membership'
134
135
  assert_difference -> { Membership.count }, 1 do
135
- post :create, body: membership_params.merge(member: {login: 'bob'}).to_json, as: :json
136
+ post :create, body: membership_params.merge(member: { login: 'bob' }).to_json, as: :json
136
137
  assert_response :ok
137
138
  end
138
139
  end
@@ -148,7 +149,7 @@ module Shipit
148
149
  test ":membership can delete an user twice" do
149
150
  @request.headers['X-Github-Event'] = 'membership'
150
151
  assert_no_difference -> { Membership.count } do
151
- post :create, body: membership_params.merge(action: 'removed', member: {login: 'bob'}).to_json, as: :json
152
+ post :create, body: membership_params.merge(action: 'removed', member: { login: 'bob' }).to_json, as: :json
152
153
  assert_response :ok
153
154
  end
154
155
  end
@@ -167,15 +168,15 @@ module Shipit
167
168
  private
168
169
 
169
170
  def pull_request_params
170
- {action: 'opened', number: 2, pull_request: 'foobar'}
171
+ { action: 'opened', number: 2, pull_request: 'foobar' }
171
172
  end
172
173
 
173
174
  def membership_params
174
- {action: 'added', team: team_params, organization: {login: 'shopify'}, member: {login: 'walrus'}}
175
+ { action: 'added', team: team_params, organization: { login: 'shopify' }, member: { login: 'walrus' } }
175
176
  end
176
177
 
177
178
  def team_params
178
- {id: shipit_teams(:shopify_developers).id, slug: 'developers', name: 'Developers', url: 'http://example.com'}
179
+ { id: shipit_teams(:shopify_developers).id, slug: 'developers', name: 'Developers', url: 'http://example.com' }
179
180
  end
180
181
 
181
182
  def george
@@ -64,4 +64,6 @@ Rails.application.configure do
64
64
  Pubsubstub.use_persistent_connections = false
65
65
 
66
66
  Shipit.disable_api_authentication = true if ENV['PUBLIC_API']
67
+
68
+ config.hosts << "shipit-engine.myshopify.io"
67
69
  end
@@ -42,5 +42,7 @@ Rails.application.configure do
42
42
 
43
43
  config.to_prepare do
44
44
  Shipit::DeferredTouch.enabled = false
45
+ # The deploy specs in fixtures are pretty printed, we should do the same to avoid marking stacks as dirty
46
+ Shipit::DeploySpec.pretty_generate = true
45
47
  end
46
48
  end
@@ -10,7 +10,7 @@
10
10
  #
11
11
  # It's strongly recommended that you check this file into your version control system.
12
12
 
13
- ActiveRecord::Schema.define(version: 2020_01_09_132519) do
13
+ ActiveRecord::Schema.define(version: 2020_06_15_181558) do
14
14
 
15
15
  create_table "api_clients", force: :cascade do |t|
16
16
  t.text "permissions", limit: 65535
@@ -78,6 +78,7 @@ ActiveRecord::Schema.define(version: 2020_01_09_132519) do
78
78
  t.integer "pull_request_id"
79
79
  t.boolean "locked", default: false, null: false
80
80
  t.integer "lock_author_id", limit: 4
81
+ t.string "pull_request_head_sha", limit: 40
81
82
  t.index ["author_id"], name: "index_commits_on_author_id"
82
83
  t.index ["committer_id"], name: "index_commits_on_committer_id"
83
84
  t.index ["created_at"], name: "index_commits_on_created_at"
@@ -260,11 +261,13 @@ ActiveRecord::Schema.define(version: 2020_01_09_132519) do
260
261
  t.datetime "ended_at"
261
262
  t.boolean "ignored_safeties", default: false, null: false
262
263
  t.integer "aborted_by_id"
264
+ t.integer "rollback_once_aborted_to_id"
263
265
  t.index ["rolled_up", "created_at", "status"], name: "index_tasks_on_rolled_up_and_created_at_and_status"
264
266
  t.index ["since_commit_id"], name: "index_tasks_on_since_commit_id"
265
267
  t.index ["stack_id", "allow_concurrency", "status"], name: "index_active_tasks"
266
268
  t.index ["stack_id", "allow_concurrency"], name: "index_tasks_on_stack_id_and_allow_concurrency"
267
269
  t.index ["stack_id", "status", "type"], name: "index_tasks_by_stack_and_status"
270
+ t.index ["status"], name: "index_tasks_on_status"
268
271
  t.index ["type", "stack_id", "parent_id"], name: "index_tasks_by_stack_and_parent"
269
272
  t.index ["until_commit_id"], name: "index_tasks_on_until_commit_id"
270
273
  t.index ["user_id"], name: "index_tasks_on_user_id"
@@ -53,6 +53,7 @@ fourth:
53
53
  deletions: 342
54
54
  updated_at: <%= 8.days.ago.to_s(:db) %>
55
55
  created_at: <%= 1.day.ago.to_s(:db) %>
56
+ pull_request_head_sha: '6dcb09b5b57875f334f61aebed695e2e4193db5e'
56
57
 
57
58
  fifth:
58
59
  id: 5
@@ -373,3 +374,17 @@ task_no_commits:
373
374
  additions: 420
374
375
  deletions: 342
375
376
  updated_at: <%= 8.days.ago.to_s(:db) %>
377
+
378
+ check_deploy_spec_first:
379
+ id: 701
380
+ sha: 547578b362bf2b4df5903e1c7960929361c3435a
381
+ message: "Removing deploy spec"
382
+ stack: check_deploy_spec
383
+ author: walrus
384
+ committer: walrus
385
+ authored_at: <%= 4.days.ago.to_s(:db) %>
386
+ committed_at: <%= 3.days.ago.to_s(:db) %>
387
+ additions: 420
388
+ deletions: 342
389
+ updated_at: <%= 8.days.ago.to_s(:db) %>
390
+
@@ -18,6 +18,10 @@ check_runs:
18
18
  owner: shopify
19
19
  name: check_runs
20
20
 
21
+ check_deploy_spec:
22
+ owner: shopify
23
+ name: check_deploy_spec
24
+
21
25
  rails:
22
26
  owner: rails
23
27
  name: rails
@@ -7,27 +7,70 @@ shipit:
7
7
  merge_queue_enabled: true
8
8
  tasks_count: 8
9
9
  undeployed_commits_count: 2
10
- cached_deploy_spec: >
10
+ cached_deploy_spec: |-
11
11
  {
12
- "machine": {"environment": {}},
12
+ "machine": {
13
+ "environment": {
14
+ }
15
+ },
13
16
  "review": {
14
- "checklist": ["foo", "bar", "baz"],
17
+ "checklist": [
18
+ "foo",
19
+ "bar",
20
+ "baz"
21
+ ],
15
22
  "monitoring": [
16
- {"image": "https://example.com/monitor.png", "width": 200, "height": 300}
23
+ {
24
+ "image": "https://example.com/monitor.png",
25
+ "width": 200,
26
+ "height": 300
27
+ }
17
28
  ]
18
29
  },
19
- "dependencies": {"override": []},
20
- "deploy": {"override": null, "interval": 60, "max_commits": 3, "variables": [{"name": "SAFETY_DISABLED", "title": "Set to 1 to do dangerous things", "default": 0}]},
21
- "rollback": {"override": ["echo 'Rollback!'"]},
22
- "fetch": ["echo '42'"],
30
+ "dependencies": {
31
+ "override": [
32
+
33
+ ]
34
+ },
35
+ "deploy": {
36
+ "override": null,
37
+ "interval": 60,
38
+ "max_commits": 3,
39
+ "variables": [
40
+ {
41
+ "name": "SAFETY_DISABLED",
42
+ "title": "Set to 1 to do dangerous things",
43
+ "default": 0
44
+ }
45
+ ]
46
+ },
47
+ "rollback": {
48
+ "override": [
49
+ "echo 'Rollback!'"
50
+ ]
51
+ },
52
+ "fetch": [
53
+ "echo '42'"
54
+ ],
23
55
  "tasks": {
24
56
  "restart": {
25
57
  "action": "Restart application",
26
58
  "description": "Restart app and job servers",
27
59
  "variables": [
28
- {"name": "FOO", "title": "Set to 0 to foo", "default": 1},
29
- {"name": "BAR", "title": "Set to 1 to bar", "default": 0},
30
- {"name": "WALRUS", "title": "Walrus without a default value"}
60
+ {
61
+ "name": "FOO",
62
+ "title": "Set to 0 to foo",
63
+ "default": 1
64
+ },
65
+ {
66
+ "name": "BAR",
67
+ "title": "Set to 1 to bar",
68
+ "default": 0
69
+ },
70
+ {
71
+ "name": "WALRUS",
72
+ "title": "Walrus without a default value"
73
+ }
31
74
  ],
32
75
  "steps": [
33
76
  "cap $ENVIRONMENT deploy:restart"
@@ -46,8 +89,12 @@ shipit:
46
89
  "revalidate_after": 900
47
90
  },
48
91
  "ci": {
49
- "hide": ["ci/hidden"],
50
- "allow_failures": ["ci/ok_to_fail"]
92
+ "hide": [
93
+ "ci/hidden"
94
+ ],
95
+ "allow_failures": [
96
+ "ci/ok_to_fail"
97
+ ]
51
98
  }
52
99
  }
53
100
  last_deployed_at: <%= 8.days.ago.to_s(:db) %>
@@ -241,7 +288,23 @@ shipit_undeployed:
241
288
  ]
242
289
  },
243
290
  "dependencies": {"override": []},
244
- "deploy": {"override": null, "interval": 60, "max_commits": 3, "variables": [{"name": "SAFETY_DISABLED", "title": "Set to 1 to do dangerous things", "default": 0}]},
291
+ "deploy": {
292
+ "override": null,
293
+ "interval": 60,
294
+ "max_commits": 3,
295
+ "variables": [
296
+ {"name": "SAFETY_DISABLED", "title": "Set to 1 to do dangerous things", "default": 0},
297
+ {
298
+ "name": "DEPLOY_REGION",
299
+ "title": "Region to deploy to",
300
+ "default": "us-central",
301
+ "select": [
302
+ "us-central",
303
+ "us-east"
304
+ ]
305
+ }
306
+ ]
307
+ },
245
308
  "rollback": {"override": ["echo 'Rollback!'"]},
246
309
  "fetch": ["echo '42'"],
247
310
  "tasks": {
@@ -404,3 +467,16 @@ shipit_task_no_commits:
404
467
  }
405
468
  }
406
469
  updated_at: <%= 8.days.ago.to_s(:db) %>
470
+
471
+ check_deploy_spec:
472
+ repository: check_deploy_spec
473
+ environment: production
474
+ branch: master
475
+ ignore_ci: true
476
+ merge_queue_enabled: true
477
+ tasks_count: 0
478
+ undeployed_commits_count: 1
479
+ continuous_deployment: true
480
+ cached_deploy_spec: "{}"
481
+ last_deployed_at: <%= 8.days.ago.to_s(:db) %>
482
+ updated_at: <%= 8.days.ago.to_s(:db) %>
@@ -1,4 +1,5 @@
1
1
  #!/usr/bin/env ruby
2
+ # frozen_string_literal: true
2
3
 
3
4
  trap('INT') do
4
5
  puts "Recieved SIGINT, aborting."
@@ -11,5 +12,5 @@ trap('TERM') do
11
12
  end
12
13
 
13
14
  puts "Sleeping for 10 seconds"
14
- sleep 10
15
+ sleep(10)
15
16
  puts "I wasn't killed? WTF"
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  module ApiHelper
2
3
  private
3
4
 
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  module FixtureAliasesHelper
2
3
  def shipit_deploys(*args)
3
4
  shipit_tasks(*args)
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  module HooksHelper
2
3
  def expect_hook(event, stack = nil, payload = nil)
3
4
  spy_on_hook
@@ -24,7 +25,7 @@ module HooksHelper
24
25
  end
25
26
  matcher = args.map(&:inspect).join(', ')
26
27
  got = called&.args&.map(&:inspect)&.join(', ')
27
- refute called, "Expected no hook matching: (#{matcher})\n got: (#{got})"
28
+ refute(called, "Expected no hook matching: (#{matcher})\n got: (#{got})")
28
29
  end
29
30
 
30
31
  private
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  module JSONHelper
2
3
  UNDEFINED = Object.new.freeze
3
4
  private_constant :UNDEFINED
@@ -9,21 +10,24 @@ module JSONHelper
9
10
  elsif expected_value == UNDEFINED
10
11
  raise ArgumentError, "Missing either expected_value or a block"
11
12
  elsif expected_value.nil?
12
- assert_nil value
13
+ assert_nil(value)
13
14
  else
14
- assert_equal expected_value, value
15
+ assert_equal(expected_value, value)
15
16
  end
16
17
  end
17
18
 
18
19
  def assert_json_keys(path, keys = nil, document: response.body)
19
- keys, path = path, nil if keys.nil?
20
+ if keys.nil?
21
+ keys = path
22
+ path = nil
23
+ end
20
24
 
21
25
  value = follow_path(path.to_s.split('.'), document: document)
22
26
  case value
23
27
  when Hash
24
- assert_equal keys.sort, value.keys.sort
28
+ assert_equal(keys.sort, value.keys.sort)
25
29
  else
26
- assert false, "Expected #{path} to be a Hash, was: #{value.inspect}"
30
+ assert(false, "Expected #{path} to be a Hash, was: #{value.inspect}")
27
31
  end
28
32
  end
29
33
 
@@ -33,11 +37,11 @@ module JSONHelper
33
37
  leaf = follow_path(segments, document: document)
34
38
  case leaf
35
39
  when Hash
36
- refute leaf.key?(last_segment), "Expected #{leaf.inspect} not to include #{last_segment.inspect}"
40
+ refute(leaf.key?(last_segment), "Expected #{leaf.inspect} not to include #{last_segment.inspect}")
37
41
  when Array
38
- refute leaf.size > last_segment.to_i, "Expected #{leaf.inspect} to not have element at index #{last_segment.to_i}"
42
+ refute(leaf.size > last_segment.to_i, "Expected #{leaf.inspect} to not have element at index #{last_segment.to_i}")
39
43
  else
40
- assert false, "Expected #{leaf.inspect} to be a Hash or Array"
44
+ assert(false, "Expected #{leaf.inspect} to be a Hash or Array")
41
45
  end
42
46
  end
43
47
 
@@ -48,13 +52,13 @@ module JSONHelper
48
52
  segments.inject(parsed_json) do |object, key|
49
53
  case object
50
54
  when Hash
51
- assert_includes object, key
55
+ assert_includes(object, key)
52
56
  object[key]
53
57
  when Array
54
- assert object.size > key.to_i, "#{object.inspect} have no property #{key}"
58
+ assert(object.size > key.to_i, "#{object.inspect} have no property #{key}")
55
59
  object[key.to_i]
56
60
  else
57
- assert false, "Expected #{object.inspect} to be a Hash or Array"
61
+ assert(false, "Expected #{object.inspect} to be a Hash or Array")
58
62
  end
59
63
  end
60
64
  end
@@ -1,13 +1,14 @@
1
+ # frozen_string_literal: true
1
2
  module LinksHelper
2
3
  LINKS_PATTERN = /\<(.*?)\>; rel="(\w+)"/
3
4
 
4
5
  def assert_link(rel, url)
5
- assert_includes response_links, rel
6
- assert_equal url, response_links[rel], %(rel="#{rel}" is incorrect)
6
+ assert_includes(response_links, rel)
7
+ assert_equal(url, response_links[rel], %(rel="#{rel}" is incorrect))
7
8
  end
8
9
 
9
10
  def assert_no_link(rel)
10
- assert_nil response_links[rel], %(expected rel="#{rel}" to be nil)
11
+ assert_nil(response_links[rel], %(expected rel="#{rel}" to be nil))
11
12
  end
12
13
 
13
14
  private
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  module PayloadsHelper
2
3
  def payload(name)
3
4
  Shipit::Engine.root.join('test/fixtures/payloads', "#{name}.json").read
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  module QueriesHelper
2
3
  def assert_no_queries(ignored_sql = nil, &block)
3
4
  assert_queries(0, ignored_sql, &block)
@@ -8,7 +9,7 @@ module QueriesHelper
8
9
  subscriber = ActiveSupport::Notifications.subscribe('sql.active_record', counter)
9
10
  yield counter
10
11
  queries = counter.log.empty? ? '' : "\nQueries:\n#{counter.log.join("\n")}"
11
- assert_equal num, counter.log.size, "#{counter.log.size} instead of #{num} queries were executed.#{queries}"
12
+ assert_equal(num, counter.log.size, "#{counter.log.size} instead of #{num} queries were executed.#{queries}")
12
13
  ensure
13
14
  ActiveSupport::Notifications.unsubscribe(subscriber)
14
15
  end
@@ -35,7 +36,7 @@ module QueriesHelper
35
36
 
36
37
  # FIXME: this needs to be refactored so specific database can add their own
37
38
  # ignored SQL. This ignored SQL is for Oracle.
38
- ignored_sql.concat [/^select .*nextval/i, /^SAVEPOINT/, /^ROLLBACK TO/, /^\s*select .* from all_triggers/im]
39
+ ignored_sql.concat([/^select .*nextval/i, /^SAVEPOINT/, /^ROLLBACK TO/, /^\s*select .* from all_triggers/im])
39
40
 
40
41
  attr_reader :ignore
41
42
  attr_reader :log