shipit-engine 0.28.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 (314) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +41 -2
  3. data/Rakefile +4 -2
  4. data/app/assets/images/archive-solid.svg +1 -0
  5. data/app/assets/stylesheets/_pages/_stacks.scss +76 -3
  6. data/app/assets/stylesheets/_structure/_main.scss +2 -1
  7. data/app/assets/stylesheets/merge_status.scss +0 -3
  8. data/app/controllers/concerns/shipit/active_model_serializers_patch.rb +13 -0
  9. data/app/controllers/concerns/shipit/api/cacheable.rb +1 -0
  10. data/app/controllers/concerns/shipit/api/paginable.rb +3 -2
  11. data/app/controllers/concerns/shipit/api/rendering.rb +5 -4
  12. data/app/controllers/concerns/shipit/authentication.rb +3 -2
  13. data/app/controllers/concerns/shipit/pagination.rb +2 -1
  14. data/app/controllers/shipit/api/base_controller.rb +11 -6
  15. data/app/controllers/shipit/api/ccmenu_controller.rb +2 -1
  16. data/app/controllers/shipit/api/commits_controller.rb +2 -1
  17. data/app/controllers/shipit/api/deploys_controller.rb +4 -3
  18. data/app/controllers/shipit/api/hooks_controller.rb +6 -5
  19. data/app/controllers/shipit/api/locks_controller.rb +5 -4
  20. data/app/controllers/shipit/api/outputs_controller.rb +2 -1
  21. data/app/controllers/shipit/api/pull_requests_controller.rb +7 -6
  22. data/app/controllers/shipit/api/release_statuses_controller.rb +3 -2
  23. data/app/controllers/shipit/api/rollbacks_controller.rb +33 -0
  24. data/app/controllers/shipit/api/stacks_controller.rb +37 -5
  25. data/app/controllers/shipit/api/tasks_controller.rb +6 -5
  26. data/app/controllers/shipit/api_clients_controller.rb +50 -0
  27. data/app/controllers/shipit/ccmenu_url_controller.rb +4 -3
  28. data/app/controllers/shipit/commit_checks_controller.rb +2 -1
  29. data/app/controllers/shipit/commits_controller.rb +2 -1
  30. data/app/controllers/shipit/deploys_controller.rb +3 -2
  31. data/app/controllers/shipit/github_authentication_controller.rb +4 -3
  32. data/app/controllers/shipit/merge_status_controller.rb +19 -14
  33. data/app/controllers/shipit/pull_requests_controller.rb +3 -2
  34. data/app/controllers/shipit/release_statuses_controller.rb +3 -2
  35. data/app/controllers/shipit/rollbacks_controller.rb +3 -2
  36. data/app/controllers/shipit/shipit_controller.rb +2 -1
  37. data/app/controllers/shipit/stacks_controller.rb +78 -14
  38. data/app/controllers/shipit/status_controller.rb +2 -1
  39. data/app/controllers/shipit/tasks_controller.rb +6 -5
  40. data/app/controllers/shipit/webhooks_controller.rb +5 -132
  41. data/app/helpers/shipit/chunks_helper.rb +1 -0
  42. data/app/helpers/shipit/deploys_helper.rb +4 -3
  43. data/app/helpers/shipit/github_url_helper.rb +1 -0
  44. data/app/helpers/shipit/merge_status_helper.rb +1 -0
  45. data/app/helpers/shipit/shipit_helper.rb +1 -0
  46. data/app/helpers/shipit/stacks_helper.rb +5 -0
  47. data/app/helpers/shipit/tasks_helper.rb +1 -0
  48. data/app/jobs/shipit/background_job.rb +4 -0
  49. data/app/jobs/shipit/background_job/unique.rb +4 -1
  50. data/app/jobs/shipit/cache_deploy_spec_job.rb +1 -0
  51. data/app/jobs/shipit/chunk_rollup_job.rb +4 -0
  52. data/app/jobs/shipit/clear_git_cache_job.rb +1 -0
  53. data/app/jobs/shipit/continuous_delivery_job.rb +3 -1
  54. data/app/jobs/shipit/create_on_github_job.rb +6 -1
  55. data/app/jobs/shipit/create_release_statuses_job.rb +1 -0
  56. data/app/jobs/shipit/deferred_touch_job.rb +4 -0
  57. data/app/jobs/shipit/deliver_hook_job.rb +1 -0
  58. data/app/jobs/shipit/destroy_job.rb +1 -0
  59. data/app/jobs/shipit/destroy_stack_job.rb +3 -2
  60. data/app/jobs/shipit/emit_event_job.rb +2 -1
  61. data/app/jobs/shipit/fetch_commit_stats_job.rb +1 -0
  62. data/app/jobs/shipit/fetch_deployed_revision_job.rb +2 -1
  63. data/app/jobs/shipit/github_sync_job.rb +3 -2
  64. data/app/jobs/shipit/{mark_deploy_healty_job.rb → mark_deploy_healthy_job.rb} +1 -0
  65. data/app/jobs/shipit/merge_pull_requests_job.rb +1 -0
  66. data/app/jobs/shipit/perform_commit_checks_job.rb +1 -0
  67. data/app/jobs/shipit/perform_task_job.rb +14 -5
  68. data/app/jobs/shipit/purge_old_deliveries_job.rb +1 -0
  69. data/app/jobs/shipit/reap_dead_tasks_job.rb +21 -0
  70. data/app/jobs/shipit/refresh_check_runs_job.rb +1 -0
  71. data/app/jobs/shipit/refresh_github_user_job.rb +1 -0
  72. data/app/jobs/shipit/refresh_pull_request_job.rb +1 -0
  73. data/app/jobs/shipit/refresh_statuses_job.rb +1 -0
  74. data/app/jobs/shipit/setup_github_hook_job.rb +1 -0
  75. data/app/jobs/shipit/update_estimated_deploy_duration_job.rb +1 -0
  76. data/app/jobs/shipit/update_github_last_deployed_ref_job.rb +6 -3
  77. data/app/models/concerns/shipit/deferred_touch.rb +4 -3
  78. data/app/models/shipit/anonymous_user.rb +5 -0
  79. data/app/models/shipit/api_client.rb +3 -2
  80. data/app/models/shipit/application_record.rb +2 -1
  81. data/app/models/shipit/check_run.rb +4 -3
  82. data/app/models/shipit/command_line_user.rb +1 -0
  83. data/app/models/shipit/commit.rb +31 -12
  84. data/app/models/shipit/commit_checks.rb +1 -0
  85. data/app/models/shipit/commit_deployment.rb +17 -12
  86. data/app/models/shipit/commit_deployment_status.rb +8 -3
  87. data/app/models/shipit/commit_message.rb +1 -0
  88. data/app/models/shipit/delivery.rb +4 -3
  89. data/app/models/shipit/deploy.rb +40 -10
  90. data/app/models/shipit/deploy_spec.rb +22 -3
  91. data/app/models/shipit/deploy_spec/bundler_discovery.rb +2 -1
  92. data/app/models/shipit/deploy_spec/capistrano_discovery.rb +1 -0
  93. data/app/models/shipit/deploy_spec/file_system.rb +10 -3
  94. data/app/models/shipit/deploy_spec/kubernetes_discovery.rb +1 -0
  95. data/app/models/shipit/deploy_spec/lerna_discovery.rb +1 -0
  96. data/app/models/shipit/deploy_spec/npm_discovery.rb +5 -4
  97. data/app/models/shipit/deploy_spec/pypi_discovery.rb +1 -0
  98. data/app/models/shipit/deploy_spec/rubygems_discovery.rb +1 -0
  99. data/app/models/shipit/deploy_stats.rb +58 -0
  100. data/app/models/shipit/duration.rb +3 -2
  101. data/app/models/shipit/ephemeral_commit_checks.rb +1 -0
  102. data/app/models/shipit/github_hook.rb +2 -1
  103. data/app/models/shipit/github_status.rb +3 -2
  104. data/app/models/shipit/hook.rb +6 -5
  105. data/app/models/shipit/membership.rb +3 -2
  106. data/app/models/shipit/output_chunk.rb +7 -2
  107. data/app/models/shipit/pull_request.rb +13 -7
  108. data/app/models/shipit/record.rb +18 -0
  109. data/app/models/shipit/release_status.rb +3 -2
  110. data/app/models/shipit/repository.rb +43 -0
  111. data/app/models/shipit/rollback.rb +1 -0
  112. data/app/models/shipit/stack.rb +109 -50
  113. data/app/models/shipit/status.rb +3 -2
  114. data/app/models/shipit/status/common.rb +7 -6
  115. data/app/models/shipit/status/group.rb +1 -0
  116. data/app/models/shipit/status/missing.rb +2 -1
  117. data/app/models/shipit/status/unknown.rb +2 -1
  118. data/app/models/shipit/task.rb +64 -9
  119. data/app/models/shipit/task_definition.rb +1 -0
  120. data/app/models/shipit/team.rb +2 -1
  121. data/app/models/shipit/undeployed_commit.rb +1 -0
  122. data/app/models/shipit/unlimited_api_client.rb +1 -0
  123. data/app/models/shipit/user.rb +29 -5
  124. data/app/models/shipit/variable_definition.rb +1 -0
  125. data/app/models/shipit/webhooks.rb +33 -0
  126. data/app/models/shipit/webhooks/handlers/check_suite_handler.rb +20 -0
  127. data/app/models/shipit/webhooks/handlers/handler.rb +41 -0
  128. data/app/models/shipit/webhooks/handlers/membership_handler.rb +46 -0
  129. data/app/models/shipit/webhooks/handlers/push_handler.rb +21 -0
  130. data/app/models/shipit/webhooks/handlers/status_handler.rb +27 -0
  131. data/app/serializers/concerns/shipit/conditional_attributes.rb +1 -0
  132. data/app/serializers/shipit/anonymous_user_serializer.rb +1 -0
  133. data/app/serializers/shipit/command_line_user_serializer.rb +1 -0
  134. data/app/serializers/shipit/commit_serializer.rb +1 -0
  135. data/app/serializers/shipit/deploy_serializer.rb +2 -1
  136. data/app/serializers/shipit/hook_serializer.rb +1 -0
  137. data/app/serializers/shipit/pull_request_serializer.rb +1 -0
  138. data/app/serializers/shipit/rollback_serializer.rb +1 -0
  139. data/app/serializers/shipit/short_commit_serializer.rb +1 -0
  140. data/app/serializers/shipit/stack_serializer.rb +7 -1
  141. data/app/serializers/shipit/tail_task_serializer.rb +1 -0
  142. data/app/serializers/shipit/task_serializer.rb +2 -17
  143. data/app/serializers/shipit/user_serializer.rb +6 -1
  144. data/app/validators/ascii_only_validator.rb +4 -3
  145. data/app/validators/subset_validator.rb +1 -0
  146. data/app/views/layouts/_head.html.erb +0 -0
  147. data/app/views/layouts/shipit.html.erb +6 -4
  148. data/app/views/shipit/_variables.html.erb +1 -1
  149. data/app/views/shipit/api_clients/index.html.erb +36 -0
  150. data/app/views/shipit/api_clients/new.html.erb +33 -0
  151. data/app/views/shipit/api_clients/show.html.erb +35 -0
  152. data/app/views/shipit/ccmenu/project.xml.builder +2 -1
  153. data/app/views/shipit/deploys/new.html.erb +17 -12
  154. data/app/views/shipit/deploys/show.html.erb +2 -2
  155. data/app/views/shipit/merge_status/logged_out.erb +1 -1
  156. data/app/views/shipit/stacks/_header.html.erb +27 -12
  157. data/app/views/shipit/stacks/_links.html.erb +1 -0
  158. data/app/views/shipit/stacks/all_tasks.html.erb +28 -0
  159. data/app/views/shipit/stacks/index.html.erb +7 -2
  160. data/app/views/shipit/stacks/settings.html.erb +19 -0
  161. data/app/views/shipit/stacks/statistics.html.erb +82 -0
  162. data/app/views/shipit/tasks/show.html.erb +1 -1
  163. data/config/initializers/inflections.rb +2 -1
  164. data/config/locales/en.yml +18 -5
  165. data/config/routes.rb +14 -2
  166. data/db/migrate/20191209231045_create_shipit_repositories.rb +12 -0
  167. data/db/migrate/20191209231307_add_repository_reference_to_stacks.rb +15 -0
  168. data/db/migrate/20191216162728_backfill_repository_data.rb +22 -0
  169. data/db/migrate/20191216163010_remove_repository_information_from_stacks.rb +20 -0
  170. data/db/migrate/20191219205202_add_archived_since_to_stacks.rb +6 -0
  171. data/db/migrate/20200102175621_optional_task_commits.rb +6 -0
  172. data/db/migrate/20200109132519_add_sha_to_commit_deployments.rb +5 -0
  173. data/db/migrate/20200226211925_add_index_to_tasks_status.rb +5 -0
  174. data/db/migrate/20200427135152_add_pull_request_head_sha_to_commit.rb +5 -0
  175. data/db/migrate/20200615181558_add_rollback_once_aborted_to.rb +5 -0
  176. data/lib/shipit.rb +18 -20
  177. data/lib/shipit/cast_value.rb +1 -0
  178. data/lib/shipit/command.rb +14 -18
  179. data/lib/shipit/commands.rb +5 -4
  180. data/lib/shipit/csv_serializer.rb +1 -0
  181. data/lib/shipit/deploy_commands.rb +1 -0
  182. data/lib/shipit/engine.rb +11 -2
  183. data/lib/shipit/environment_variables.rb +11 -1
  184. data/lib/shipit/first_parent_commits_iterator.rb +1 -0
  185. data/lib/shipit/flock.rb +1 -0
  186. data/lib/shipit/github_app.rb +60 -6
  187. data/lib/shipit/github_http_cache_middleware.rb +57 -0
  188. data/lib/shipit/null_serializer.rb +1 -0
  189. data/lib/shipit/octokit_check_runs.rb +3 -2
  190. data/lib/shipit/octokit_iterator.rb +3 -2
  191. data/lib/shipit/paginator.rb +3 -2
  192. data/lib/shipit/rollback_commands.rb +1 -0
  193. data/lib/shipit/same_site_cookie_middleware.rb +29 -0
  194. data/lib/shipit/simple_message_verifier.rb +1 -0
  195. data/lib/shipit/stack_commands.rb +6 -3
  196. data/lib/shipit/stat.rb +1 -0
  197. data/lib/shipit/task_commands.rb +22 -14
  198. data/lib/shipit/version.rb +2 -1
  199. data/lib/snippets/release-gem +5 -1
  200. data/lib/tasks/cron.rake +2 -0
  201. data/lib/tasks/dev.rake +3 -2
  202. data/lib/tasks/shipit.rake +16 -17
  203. data/lib/tasks/teams.rake +1 -0
  204. data/test/controllers/api/base_controller_test.rb +3 -2
  205. data/test/controllers/api/ccmenu_controller_test.rb +9 -8
  206. data/test/controllers/api/commits_controller_test.rb +3 -2
  207. data/test/controllers/api/deploys_controller_test.rb +15 -14
  208. data/test/controllers/api/hooks_controller_test.rb +8 -7
  209. data/test/controllers/api/locks_controller_test.rb +7 -6
  210. data/test/controllers/api/outputs_controller_test.rb +3 -2
  211. data/test/controllers/api/pull_requests_controller_test.rb +8 -7
  212. data/test/controllers/api/release_statuses_controller_test.rb +2 -1
  213. data/test/controllers/api/rollback_controller_test.rb +113 -0
  214. data/test/controllers/api/stacks_controller_test.rb +44 -15
  215. data/test/controllers/api/tasks_controller_test.rb +13 -12
  216. data/test/controllers/api_clients_controller_test.rb +104 -0
  217. data/test/controllers/ccmenu_controller_test.rb +4 -3
  218. data/test/controllers/commit_checks_controller_test.rb +4 -3
  219. data/test/controllers/commits_controller_test.rb +3 -2
  220. data/test/controllers/deploys_controller_test.rb +33 -22
  221. data/test/controllers/github_authentication_controller_test.rb +1 -0
  222. data/test/controllers/merge_status_controller_test.rb +27 -9
  223. data/test/controllers/pull_requests_controller_test.rb +4 -3
  224. data/test/controllers/release_statuses_controller_test.rb +3 -2
  225. data/test/controllers/rollbacks_controller_test.rb +9 -8
  226. data/test/controllers/stacks_controller_test.rb +64 -15
  227. data/test/controllers/status_controller_test.rb +1 -0
  228. data/test/controllers/tasks_controller_test.rb +20 -19
  229. data/test/controllers/webhooks_controller_test.rb +36 -9
  230. data/test/dummy/config/application.rb +1 -1
  231. data/test/dummy/config/environments/development.rb +24 -4
  232. data/test/dummy/config/environments/test.rb +2 -0
  233. data/test/dummy/db/schema.rb +25 -11
  234. data/test/dummy/db/seeds.rb +34 -17
  235. data/test/fixtures/shipit/commit_deployment_statuses.yml +4 -4
  236. data/test/fixtures/shipit/commit_deployments.yml +8 -8
  237. data/test/fixtures/shipit/commits.yml +38 -0
  238. data/test/fixtures/shipit/repositories.yml +27 -0
  239. data/test/fixtures/shipit/stacks.yml +190 -30
  240. data/test/fixtures/shipit/tasks.yml +66 -3
  241. data/test/fixtures/timeout +2 -1
  242. data/test/helpers/api_helper.rb +1 -0
  243. data/test/helpers/fixture_aliases_helper.rb +1 -0
  244. data/test/helpers/hooks_helper.rb +2 -1
  245. data/test/helpers/json_helper.rb +15 -11
  246. data/test/helpers/links_helper.rb +4 -3
  247. data/test/helpers/payloads_helper.rb +1 -0
  248. data/test/helpers/queries_helper.rb +3 -2
  249. data/test/jobs/cache_deploy_spec_job_test.rb +2 -1
  250. data/test/jobs/chunk_rollup_job_test.rb +1 -0
  251. data/test/jobs/deliver_hook_job_test.rb +2 -1
  252. data/test/jobs/destroy_stack_job_test.rb +10 -0
  253. data/test/jobs/emit_event_job_test.rb +2 -1
  254. data/test/jobs/fetch_commit_stats_job_test.rb +1 -0
  255. data/test/jobs/fetch_deployed_revision_job_test.rb +1 -0
  256. data/test/jobs/github_sync_job_test.rb +1 -0
  257. data/test/jobs/mark_deploy_healthy_job_test.rb +1 -0
  258. data/test/jobs/merge_pull_requests_job_test.rb +5 -4
  259. data/test/jobs/perform_task_job_test.rb +4 -3
  260. data/test/jobs/purge_old_deliveries_job_test.rb +1 -0
  261. data/test/jobs/reap_dead_tasks_job_test.rb +68 -0
  262. data/test/jobs/refresh_github_user_job_test.rb +1 -0
  263. data/test/jobs/refresh_status_job_test.rb +1 -0
  264. data/test/jobs/unique_job_test.rb +1 -0
  265. data/test/jobs/update_github_last_deployed_ref_job_test.rb +13 -11
  266. data/test/middleware/same_site_cookie_middleware_test.rb +52 -0
  267. data/test/models/api_client_test.rb +1 -0
  268. data/test/models/commit_checks_test.rb +1 -0
  269. data/test/models/commit_deployment_status_test.rb +34 -4
  270. data/test/models/commit_deployment_test.rb +9 -11
  271. data/test/models/commits_test.rb +99 -7
  272. data/test/models/delivery_test.rb +3 -2
  273. data/test/models/deploy_spec_test.rb +47 -42
  274. data/test/models/deploy_stats_test.rb +113 -0
  275. data/test/models/deploys_test.rb +60 -13
  276. data/test/models/duration_test.rb +1 -0
  277. data/test/models/github_hook_test.rb +1 -0
  278. data/test/models/hook_test.rb +20 -16
  279. data/test/models/membership_test.rb +1 -0
  280. data/test/models/output_chunk_test.rb +1 -0
  281. data/test/models/pull_request_test.rb +18 -11
  282. data/test/models/release_statuses_test.rb +1 -0
  283. data/test/models/rollbacks_test.rb +1 -0
  284. data/test/models/shipit/check_run_test.rb +1 -0
  285. data/test/models/shipit/repository_test.rb +77 -0
  286. data/test/models/shipit/wehbooks/handlers_test.rb +27 -0
  287. data/test/models/stacks_test.rb +110 -56
  288. data/test/models/status/group_test.rb +1 -0
  289. data/test/models/status/missing_test.rb +1 -0
  290. data/test/models/status_test.rb +1 -0
  291. data/test/models/task_definitions_test.rb +9 -8
  292. data/test/models/tasks_test.rb +18 -1
  293. data/test/models/team_test.rb +4 -2
  294. data/test/models/undeployed_commits_test.rb +14 -0
  295. data/test/models/users_test.rb +109 -1
  296. data/test/test_command_integration.rb +3 -2
  297. data/test/test_helper.rb +38 -34
  298. data/test/unit/anonymous_user_serializer_test.rb +14 -0
  299. data/test/unit/command_test.rb +12 -7
  300. data/test/unit/commands_test.rb +1 -0
  301. data/test/unit/commit_serializer_test.rb +16 -0
  302. data/test/unit/csv_serializer_test.rb +3 -2
  303. data/test/unit/deploy_commands_test.rb +14 -4
  304. data/test/unit/deploy_serializer_test.rb +17 -0
  305. data/test/unit/environment_variables_test.rb +5 -4
  306. data/test/unit/github_app_test.rb +165 -0
  307. data/test/unit/github_url_helper_test.rb +1 -0
  308. data/test/unit/rollback_commands_test.rb +2 -1
  309. data/test/unit/shipit_helper_test.rb +17 -0
  310. data/test/unit/shipit_test.rb +1 -0
  311. data/test/unit/user_serializer_test.rb +14 -0
  312. data/test/unit/variable_definition_test.rb +1 -0
  313. metadata +215 -157
  314. data/lib/shipit/strip_cache_control.rb +0 -40
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  module Shipit
2
3
  class SimpleMessageVerifier < ActiveSupport::MessageVerifier
3
4
  def initialize(secret, options = {})
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  require 'pathname'
2
3
  require 'fileutils'
3
4
 
@@ -26,7 +27,7 @@ module Shipit
26
27
  end
27
28
 
28
29
  def fetch_deployed_revision
29
- with_temporary_working_directory(commit: @stack.commits.last) do |dir|
30
+ with_temporary_working_directory(commit: @stack.commits.reachable.last) do |dir|
30
31
  spec = DeploySpec::FileSystem.new(dir, @stack.environment)
31
32
  outputs = spec.fetch_deployed_revision_steps!.map do |command_line|
32
33
  Command.new(command_line, env: env, chdir: dir).run
@@ -42,11 +43,13 @@ module Shipit
42
43
  end
43
44
 
44
45
  def with_temporary_working_directory(commit: nil)
45
- commit ||= @stack.last_deployed_commit.presence || @stack.commits.last
46
+ commit ||= @stack.last_deployed_commit.presence || @stack.commits.reachable.last
46
47
 
47
48
  if !commit || !fetched?(commit).tap(&:run).success?
48
49
  @stack.acquire_git_cache_lock do
49
- fetch.run!
50
+ unless fetched?(commit).tap(&:run).success?
51
+ fetch.run!
52
+ end
50
53
  end
51
54
  end
52
55
 
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  module Shipit
2
3
  module Stat
3
4
  extend self
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  module Shipit
2
3
  class TaskCommands < Commands
3
4
  delegate :fetch, :fetched?, to: :stack_commands
@@ -28,20 +29,20 @@ module Shipit
28
29
  end
29
30
 
30
31
  def env
31
- normalized_name = ActiveSupport::Inflector.transliterate(@task.author.name)
32
- super.merge(
33
- 'ENVIRONMENT' => @stack.environment,
34
- 'BRANCH' => @stack.branch,
35
- 'SHIPIT_USER' => "#{@task.author.login} (#{normalized_name}) via Shipit",
36
- 'EMAIL' => @task.author.email,
37
- 'BUNDLE_PATH' => Rails.root.join('data', 'bundler').to_s,
38
- 'SHIPIT_LINK' => @task.permalink,
39
- 'LAST_DEPLOYED_SHA' => @stack.last_deployed_commit.sha,
40
- 'TASK_ID' => @task.id.to_s,
41
- 'IGNORED_SAFETIES' => @task.ignored_safeties? ? '1' : '0',
42
- 'GIT_COMMITTER_NAME' => @task.user&.name || Shipit.committer_name,
43
- 'GIT_COMMITTER_EMAIL' => @task.user&.email || Shipit.committer_email,
44
- ).merge(deploy_spec.machine_env).merge(@task.env)
32
+ super
33
+ .merge(@stack.env)
34
+ .merge(
35
+ 'SHIPIT_USER' => "#{@task.author.login} (#{normalized_author_name}) via Shipit",
36
+ 'EMAIL' => @task.author.email,
37
+ 'BUNDLE_PATH' => Rails.root.join('data', 'bundler').to_s,
38
+ 'SHIPIT_LINK' => @task.permalink,
39
+ 'TASK_ID' => @task.id.to_s,
40
+ 'IGNORED_SAFETIES' => @task.ignored_safeties? ? '1' : '0',
41
+ 'GIT_COMMITTER_NAME' => @task.user&.name || Shipit.committer_name,
42
+ 'GIT_COMMITTER_EMAIL' => @task.user&.email || Shipit.committer_email,
43
+ )
44
+ .merge(deploy_spec.machine_env)
45
+ .merge(@task.env)
45
46
  end
46
47
 
47
48
  def checkout(commit)
@@ -52,6 +53,7 @@ module Shipit
52
53
  [
53
54
  git(
54
55
  'clone',
56
+ '--quiet',
55
57
  '--local',
56
58
  '--origin', 'cache',
57
59
  @stack.git_path,
@@ -70,6 +72,12 @@ module Shipit
70
72
  FileUtils.rm_rf(@task.working_directory) if deploy_spec.clear_working_directory?
71
73
  end
72
74
 
75
+ private
76
+
77
+ def normalized_author_name
78
+ ActiveSupport::Inflector.transliterate(@task.author.name)
79
+ end
80
+
73
81
  protected
74
82
 
75
83
  def steps_directory
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  module Shipit
2
- VERSION = '0.28.0'.freeze
3
+ VERSION = '0.32.0'
3
4
  end
@@ -50,8 +50,12 @@ spec = Gem::Specification.load(spec_path)
50
50
  if RubygemsAPI.published?(spec.name, spec.version)
51
51
  puts "#{spec.name} version #{spec.version} is already published."
52
52
  exit 0
53
+ elsif !spec.metadata['allowed_push_host']
54
+ puts "Can't release the gem: spec.metadata['allowed_push_host'] must be defined."
55
+ exit 1
53
56
  else
54
- Git.tag_and_push(spec.version) do
57
+ is_successful = Git.tag_and_push(spec.version) do
55
58
  system(*release_command)
56
59
  end
60
+ is_successful ? exit(0) : exit(1)
57
61
  end
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  namespace :cron do
2
3
  desc "Updates deployed revisions"
3
4
  task minutely: :environment do
@@ -5,6 +6,7 @@ namespace :cron do
5
6
  Shipit::Stack.schedule_continuous_delivery
6
7
  Shipit::GithubStatus.refresh_status
7
8
  Shipit::PullRequest.schedule_merges
9
+ Shipit::ReapDeadTasksJob.perform_later
8
10
  end
9
11
 
10
12
  task hourly: %i(rollup refresh_users)
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  namespace :dev do
2
3
  desc "Appends chunks to the last deploy, or specify with DEPLOY=id"
3
4
  task stream: :environment do
@@ -11,7 +12,7 @@ namespace :dev do
11
12
 
12
13
  deploy.update_attribute(:output, nil)
13
14
 
14
- logger.info "Starting to stream data to deploy ##{deploy.id}"
15
+ logger.info("Starting to stream data to deploy ##{deploy.id}")
15
16
 
16
17
  loop do
17
18
  sentence = Faker::Lorem.sentence.split.map do |word|
@@ -22,7 +23,7 @@ namespace :dev do
22
23
  end
23
24
  end.join(' ')
24
25
 
25
- logger.error sentence
26
+ logger.error(sentence)
26
27
 
27
28
  deploy.chunks.create(text: sentence + "\n")
28
29
  sleep 1
@@ -1,27 +1,26 @@
1
+ # frozen_string_literal: true
1
2
  namespace :shipit do
2
3
  desc "Deploy from a running instance. "
3
4
  task deploy: :environment do
4
- begin
5
- stack = ENV['stack']
6
- revision = ENV['revision']
5
+ stack = ENV['stack']
6
+ revision = ENV['revision']
7
7
 
8
- raise ArgumentError.new('The first argument has to be a stack, e.g. shopify/shipit/production') if stack.nil?
9
- raise ArgumentError.new('The second argument has to be a revision') if revision.nil?
8
+ raise ArgumentError, 'The first argument has to be a stack, e.g. shopify/shipit/production' if stack.nil?
9
+ raise ArgumentError, 'The second argument has to be a revision' if revision.nil?
10
10
 
11
- module Shipit
12
- class Task
13
- def write(text)
14
- p text
15
- chunks.create!(text: text)
16
- end
11
+ module Shipit
12
+ class Task
13
+ def write(text)
14
+ p(text)
15
+ chunks.create!(text: text)
17
16
  end
18
17
  end
19
-
20
- Shipit::Stack.run_deploy_in_foreground(stack: stack, revision: revision)
21
- rescue ArgumentError
22
- p "Use this command as follows:"
23
- p "bundle exec rake shipit:deploy stack='shopify/shipit/production' revision='$SHA'"
24
- raise
25
18
  end
19
+
20
+ Shipit::Stack.run_deploy_in_foreground(stack: stack, revision: revision)
21
+ rescue ArgumentError
22
+ p("Use this command as follows:")
23
+ p("bundle exec rake shipit:deploy stack='shopify/shipit/production' revision='$SHA'")
24
+ raise
26
25
  end
27
26
  end
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  namespace :teams do
2
3
  desc "Import the members of each team configured through the github.oauth.teams config"
3
4
  task fetch: :environment do
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  require 'test_helper'
2
3
 
3
4
  module Shipit
@@ -6,7 +7,7 @@ module Shipit
6
7
  test "authentication is required" do
7
8
  get :index
8
9
  assert_response :unauthorized
9
- assert_equal({message: 'Bad credentials'}.to_json, response.body)
10
+ assert_equal({ message: 'Bad credentials' }.to_json, response.body)
10
11
  end
11
12
 
12
13
  test "with proper credentials the request is processed" do
@@ -17,7 +18,7 @@ module Shipit
17
18
  test "#index respond with a list of endpoints" do
18
19
  authenticate!
19
20
  get :index, format: :json
20
- assert_equal({stacks_url: api_stacks_url}.to_json, response.body)
21
+ assert_equal({ stacks_url: api_stacks_url }.to_json, response.body)
21
22
  end
22
23
  end
23
24
  end
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  require 'test_helper'
2
3
 
3
4
  module Shipit
@@ -10,26 +11,26 @@ module Shipit
10
11
 
11
12
  test "a request with insufficient permissions will render a 403" do
12
13
  @client.update!(permissions: [])
13
- get :show, params: {stack_id: @stack.to_param}
14
+ get :show, params: { stack_id: @stack.to_param }
14
15
  assert_response :forbidden
15
16
  assert_json 'message', 'This operation requires the `read:stack` permission'
16
17
  end
17
18
 
18
19
  test "#show renders the xml" do
19
- get :show, params: {stack_id: @stack.to_param}
20
+ get :show, params: { stack_id: @stack.to_param }
20
21
  assert_response :ok
21
22
  assert_payload 'name', @stack.to_param
22
23
  end
23
24
 
24
25
  test "can authenticate with query string token" do
25
26
  request.headers['Authorization'] = 'bleh'
26
- get :show, params: {stack_id: @stack.to_param, token: @client.authentication_token}
27
+ get :show, params: { stack_id: @stack.to_param, token: @client.authentication_token }
27
28
  assert_response :ok
28
29
  assert_payload 'name', @stack.to_param
29
30
  end
30
31
 
31
32
  test "xml contains required attributes" do
32
- get :show, params: {stack_id: @stack.to_param}
33
+ get :show, params: { stack_id: @stack.to_param }
33
34
  project = get_project_from_xml(response.body)
34
35
  %w(name activity lastBuildStatus lastBuildLabel lastBuildTime webUrl).each do |attribute|
35
36
  assert_includes project, attribute, "Response missing required attribute: #{attribute}"
@@ -38,13 +39,13 @@ module Shipit
38
39
 
39
40
  test "locked stacks show as failed" do
40
41
  @stack.lock('test', @user)
41
- get :show, params: {stack_id: @stack.to_param}
42
+ get :show, params: { stack_id: @stack.to_param }
42
43
  assert_payload 'lastBuildStatus', 'Failure'
43
44
  end
44
45
 
45
46
  test "stacks with no deploys render correctly" do
46
- stack = Stack.create!(repo_owner: 'foo', repo_name: 'bar')
47
- get :show, params: {stack_id: stack.to_param}
47
+ stack = Stack.create!(repository: Repository.new(owner: "foo", name: "bar"))
48
+ get :show, params: { stack_id: stack.to_param }
48
49
  assert_payload 'lastBuildStatus', 'Success'
49
50
  end
50
51
 
@@ -56,7 +57,7 @@ module Shipit
56
57
 
57
58
  def assert_payload(k, v)
58
59
  @project ||= get_project_from_xml(response.body)
59
- assert_equal v, @project[k]
60
+ assert_equal(v, @project[k])
60
61
  end
61
62
  end
62
63
  end
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  require 'test_helper'
2
3
 
3
4
  module Shipit
@@ -11,7 +12,7 @@ module Shipit
11
12
  test "#index returns a list of commits" do
12
13
  commit = @stack.commits.reachable.last
13
14
 
14
- get :index, params: {stack_id: @stack.to_param}
15
+ get :index, params: { stack_id: @stack.to_param }
15
16
  assert_response :ok
16
17
  assert_json '0.sha', commit.sha
17
18
  end
@@ -19,7 +20,7 @@ module Shipit
19
20
  test "#index with undeployed=1 returns a list of undeployed commits" do
20
21
  commits = @stack.undeployed_commits.pluck(:sha)
21
22
 
22
- get :index, params: {stack_id: @stack.to_param, undeployed: 1}
23
+ get :index, params: { stack_id: @stack.to_param, undeployed: 1 }
23
24
  assert_response :ok
24
25
  JSON.parse(response.body).each do |commit|
25
26
  assert commits.include?(commit.fetch("sha"))
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  require 'test_helper'
2
3
 
3
4
  module Shipit
@@ -13,7 +14,7 @@ module Shipit
13
14
  test "#deploys returns the deploys and revisions for a given stack" do
14
15
  tasks = @stack.deploys_and_rollbacks.order(id: :desc)
15
16
 
16
- get :index, params: {stack_id: @stack.to_param}
17
+ get :index, params: { stack_id: @stack.to_param }
17
18
  assert_response :ok
18
19
 
19
20
  (0...tasks.length).each do |i|
@@ -23,60 +24,60 @@ module Shipit
23
24
 
24
25
  test "#create triggers a new deploy for the stack" do
25
26
  assert_difference -> { @stack.deploys.count }, 1 do
26
- post :create, params: {stack_id: @stack.to_param, sha: @commit.sha}
27
+ post :create, params: { stack_id: @stack.to_param, sha: @commit.sha }
27
28
  end
28
29
  assert_response :accepted
29
30
  assert_json 'status', 'pending'
30
31
  end
31
32
 
32
33
  test "#create triggers a new deploy for whitelisted variables" do
33
- correct_env = {'SAFETY_DISABLED' => 1}
34
- post :create, params: {stack_id: @stack.to_param, sha: @commit.sha, env: correct_env}
34
+ correct_env = { 'SAFETY_DISABLED' => 1 }
35
+ post :create, params: { stack_id: @stack.to_param, sha: @commit.sha, env: correct_env }
35
36
  assert_response :accepted
36
37
  assert_json 'type', 'deploy'
37
38
  assert_json 'status', 'pending'
38
39
  end
39
40
 
40
41
  test "#create refuses to trigger a new deploy with incorrect variables" do
41
- incorrect_env = {'DANGEROUS_VARIABLE' => 1}
42
- post :create, params: {stack_id: @stack.to_param, sha: @commit.sha, env: incorrect_env}
42
+ incorrect_env = { 'DANGEROUS_VARIABLE' => 1 }
43
+ post :create, params: { stack_id: @stack.to_param, sha: @commit.sha, env: incorrect_env }
43
44
  assert_response :unprocessable_entity
44
45
  assert_json 'message', 'Variables DANGEROUS_VARIABLE have not been whitelisted'
45
46
  end
46
47
 
47
48
  test "#create use the claimed user as author" do
48
49
  request.headers['X-Shipit-User'] = @user.login
49
- post :create, params: {stack_id: @stack.to_param, sha: @commit.sha}
50
+ post :create, params: { stack_id: @stack.to_param, sha: @commit.sha }
50
51
  deploy = Deploy.last
51
52
  deploy.user == @user
52
53
  end
53
54
 
54
55
  test "#create normalises the claimed user" do
55
56
  request.headers['X-Shipit-User'] = @user.login.swapcase
56
- post :create, params: {stack_id: @stack.to_param, sha: @commit.sha}
57
+ post :create, params: { stack_id: @stack.to_param, sha: @commit.sha }
57
58
  deploy = Deploy.last
58
59
  assert_equal deploy.user, @user
59
60
  end
60
61
 
61
62
  test "#create renders a 422 if the sha isn't found" do
62
- post :create, params: {stack_id: @stack.to_param, sha: '123443543545'}
63
+ post :create, params: { stack_id: @stack.to_param, sha: '123443543545' }
63
64
  assert_response :unprocessable_entity
64
65
  assert_json 'errors', 'sha' => ['Unknown revision']
65
66
  end
66
67
 
67
68
  test "#create renders a 422 if the sha format is invalid" do
68
- post :create, params: {stack_id: @stack.to_param, sha: '1'}
69
+ post :create, params: { stack_id: @stack.to_param, sha: '1' }
69
70
  assert_response :unprocessable_entity
70
71
  assert_json 'errors', 'sha' => ['is too short (minimum is 6 characters)']
71
72
  end
72
73
 
73
74
  test "#create renders a 409 if a concurrent task is already running" do
74
75
  assert_difference -> { @stack.deploys.count }, 1 do
75
- post :create, params: {stack_id: @stack.to_param, sha: @commit.sha}
76
+ post :create, params: { stack_id: @stack.to_param, sha: @commit.sha }
76
77
  end
77
78
 
78
79
  assert_no_difference -> { @stack.deploys.count } do
79
- post :create, params: {stack_id: @stack.to_param, sha: @commit.sha}
80
+ post :create, params: { stack_id: @stack.to_param, sha: @commit.sha }
80
81
  end
81
82
 
82
83
  assert_response :conflict
@@ -86,7 +87,7 @@ module Shipit
86
87
  @stack.update!(lock_reason: 'Something broken')
87
88
 
88
89
  assert_no_difference -> { @stack.deploys.count } do
89
- post :create, params: {stack_id: @stack.to_param, sha: @commit.sha}
90
+ post :create, params: { stack_id: @stack.to_param, sha: @commit.sha }
90
91
  end
91
92
  assert_response :unprocessable_entity
92
93
  assert_json 'errors.force', ["Can't deploy a locked stack"]
@@ -96,7 +97,7 @@ module Shipit
96
97
  @stack.update!(lock_reason: 'Something broken')
97
98
 
98
99
  assert_difference -> { @stack.deploys.count }, 1 do
99
- post :create, params: {stack_id: @stack.to_param, sha: @commit.sha, force: 'true'}
100
+ post :create, params: { stack_id: @stack.to_param, sha: @commit.sha, force: 'true' }
100
101
  end
101
102
  assert_response :accepted
102
103
  assert_json 'status', 'pending'
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  require 'test_helper'
2
3
 
3
4
  module Shipit
@@ -9,7 +10,7 @@ module Shipit
9
10
  end
10
11
 
11
12
  test "the route has priority over stacks one" do
12
- assert_recognizes({controller: 'shipit/api/hooks', action: 'show', id: '42'}, '/api/hooks/42')
13
+ assert_recognizes({ controller: 'shipit/api/hooks', action: 'show', id: '42' }, '/api/hooks/42')
13
14
  end
14
15
 
15
16
  test "#index without a stack_id returns the list of global hooks" do
@@ -26,7 +27,7 @@ module Shipit
26
27
  test "#index with a stack_id returns the list of scoped hooks" do
27
28
  hook = Hook.scoped_to(@stack).first
28
29
 
29
- get :index, params: {stack_id: @stack.to_param}
30
+ get :index, params: { stack_id: @stack.to_param }
30
31
  assert_response :ok
31
32
  assert_json '0.id', hook.id
32
33
  assert_json '0.delivery_url', hook.delivery_url
@@ -37,7 +38,7 @@ module Shipit
37
38
  test "#show returns the hooks" do
38
39
  hook = Hook.scoped_to(@stack).first
39
40
 
40
- get :show, params: {stack_id: @stack.to_param, id: hook.id}
41
+ get :show, params: { stack_id: @stack.to_param, id: hook.id }
41
42
  assert_response :ok
42
43
 
43
44
  assert_json 'id', hook.id
@@ -48,7 +49,7 @@ module Shipit
48
49
 
49
50
  test "#create adds a new hook" do
50
51
  assert_difference -> { Hook.count }, 1 do
51
- post :create, params: {delivery_url: 'https://example.com/hook', events: %w(deploy rollback)}
52
+ post :create, params: { delivery_url: 'https://example.com/hook', events: %w(deploy rollback) }
52
53
  end
53
54
  hook = Hook.last
54
55
  assert_json 'delivery_url', 'https://example.com/hook'
@@ -66,21 +67,21 @@ module Shipit
66
67
  end
67
68
 
68
69
  test "#create returns validation errors" do
69
- post :create, params: {delivery_url: '../etc/passwd', events: %w(deploy)}
70
+ post :create, params: { delivery_url: '../etc/passwd', events: %w(deploy) }
70
71
  assert_response :unprocessable_entity
71
72
  assert_json 'errors', 'delivery_url' => ['is not a valid URL']
72
73
  end
73
74
 
74
75
  test "#update changes an existing hook" do
75
76
  hook = Hook.global.first
76
- patch :update, params: {id: hook.id, delivery_url: 'https://shipit.com/'}
77
+ patch :update, params: { id: hook.id, delivery_url: 'https://shipit.com/' }
77
78
  assert_response :ok
78
79
  assert_json 'delivery_url', 'https://shipit.com/'
79
80
  end
80
81
 
81
82
  test "#destroy removes an existing hook" do
82
83
  hook = Hook.global.first
83
- delete :destroy, params: {id: hook.id}
84
+ delete :destroy, params: { id: hook.id }
84
85
  assert_response :no_content
85
86
  end
86
87
  end