prima-twig 0.62.14 → 0.62.15

Sign up to get free protection for your applications and to get access to all the features.
Files changed (4) hide show
  1. checksums.yaml +4 -4
  2. data/bin/twig-feature +53 -113
  3. data/bin/twig-update-ami +22 -27
  4. metadata +3 -3
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 3caafc6bb385562064c170270faf751c57ffcd6634f15dfe2af39d1852b50eae
4
- data.tar.gz: 151953c4023ca1cbdd7150b4d0be3ac82c9e3f3a9ab0d9bbfd973c0e3740c6bb
3
+ metadata.gz: 535bfd11c3493fd0cdcd803cb3bdd2362d32b1906ba2ceab21e8b3eb43eb4247
4
+ data.tar.gz: 4e5ab696bc9633fe029f7081a42e998e2133b142baa62363ae1f5137ecfba4ab
5
5
  SHA512:
6
- metadata.gz: 0acd7f7d815bcdfb9ed7742f7540d9488846ecdaf64f891991610bbb0570f6b020e400a425081b6a50663b289f248d4332069fcfe09848c930c0e364a1b67d66
7
- data.tar.gz: 054420250a5193dacc5d018f79c9f4fe11783e7c772b3edd6a80ec9c5d0e261b9d6ec595b9781e6d8099f640f06de90421dc6800d7c250b4056e707f4e158f18
6
+ metadata.gz: 1e61b9ec19e1c0316abc18875b0bd38d7bbf22fc6004d54100f2665bf1c0ba9b2a18655cc1c8d25473d2d71be3506e6d6336ad9e8178824dcb7ac8c32341c63e
7
+ data.tar.gz: b6b16a0832f22d2ba56dd9fa5a776f27b552a9eb5304afd5aae749430a316fa0026896ab58cfe63f52ec5adb5f92d248b11497691eab97fbf7784f7b11af8c81
data/bin/twig-feature CHANGED
@@ -26,7 +26,7 @@ class Release
26
26
  @s3 = Aws::S3::Client.new
27
27
  @s3_bucket = 'prima-artifacts'
28
28
  @artifact_path = '/tmp/prima-artifact.zip'
29
- @import_db_task = 'arn:aws:ecs:eu-west-1:001575623345:task-definition/ecs-task-db-restore2-TaskDefinitionDbRestore-P358L3UYOC6F:1'
29
+ @import_db_task = 'arn:aws:ecs:eu-west-1:001575623345:task-definition/ecs-task-db-restore2-TaskDefinitionDbRestore-4UBHMCZBE5WM:1'
30
30
  @cf_role = 'arn:aws:iam::001575623345:role/qainit-service-role-cloudformat-CloudformationRole-18KBZQIS148R9'
31
31
  @dns_record_identifier = nil
32
32
  @ecs_cluster_name = nil
@@ -1510,20 +1510,20 @@ class Release
1510
1510
 
1511
1511
  stack_name_web = "ecs-task-web-qa-#{deploy_id}"
1512
1512
  git_checkout_version('prima', @projects["prima"]['revision'])
1513
- stack_body = IO.read('projects/prima/app/cloudformation/tasks/web.yml')
1513
+ stack_body = IO.read('projects/prima/app/cloudformation/tasks/web-qa.yml')
1514
1514
  parameters = [
1515
- {
1516
- parameter_key: "Environment",
1517
- parameter_value: "qa"
1518
- },
1515
+ # {
1516
+ # parameter_key: "Environment",
1517
+ # parameter_value: "qa"
1518
+ # },
1519
1519
  {
1520
1520
  parameter_key: "ReleaseVersion",
1521
1521
  parameter_value: "#{@projects["prima"]['revision']}"
1522
1522
  },
1523
- {
1524
- parameter_key: "TaskDesiredCount",
1525
- parameter_value: "1"
1526
- },
1523
+ # {
1524
+ # parameter_key: "TaskDesiredCount",
1525
+ # parameter_value: "1"
1526
+ # },
1527
1527
  {
1528
1528
  parameter_key: "ECSClusterName",
1529
1529
  parameter_value: @ecs_cluster_name
@@ -1591,30 +1591,6 @@ class Release
1591
1591
  {
1592
1592
  parameter_key: "ECSClusterName",
1593
1593
  parameter_value: @ecs_cluster_name
1594
- },
1595
- {
1596
- parameter_key: "NginxHttpHost",
1597
- parameter_value: "www-#{@dns_record_identifier}.qa.colaster.com"
1598
- },
1599
- {
1600
- parameter_key: "AssangeHostname",
1601
- parameter_value: "assange-#{@dns_record_identifier}.qa.colaster.com"
1602
- },
1603
- {
1604
- parameter_key: "BackofficeHostname",
1605
- parameter_value: "backoffice-#{@dns_record_identifier}.qa.colaster.com"
1606
- },
1607
- {
1608
- parameter_key: "WebHostname",
1609
- parameter_value: "www-#{@dns_record_identifier}.qa.colaster.com"
1610
- },
1611
- {
1612
- parameter_key: "FePrimaDomain",
1613
- parameter_value: "www-#{@dns_record_identifier}.qa.colaster.com"
1614
- },
1615
- {
1616
- parameter_key: "HostnamePattern",
1617
- parameter_value: "consumer-#{@dns_record_identifier}.qa.colaster.com"
1618
1594
  }
1619
1595
  ]
1620
1596
  if stack_exists?(stack_name_consumer)
@@ -1810,8 +1786,7 @@ class Release
1810
1786
  starsky_hostname = get_route53_hostname("starsky") unless !deploy_starsky_hutch?
1811
1787
  hutch_hostname = get_route53_hostname("hutch") unless !deploy_starsky_hutch?
1812
1788
 
1813
-
1814
- # launch_marley ec2_ip_address(asg_stack_name), prima_hostname, borat_hostname
1789
+ launch_mimo(deploy_id) if deploy_starsky_hutch?
1815
1790
 
1816
1791
  projects_text = "
1817
1792
  > Prima url: https://#{prima_hostname}
@@ -2091,26 +2066,7 @@ class Release
2091
2066
  exec_step 'cp docker-compose.yml docker-compose-ci.yml'
2092
2067
  exec_step 'prepare-docker-compose --directory activia && cp docker-compose-qainit.yml docker-compose.yml'
2093
2068
 
2094
- if File.exists? 'deploy/build_qa_artifact'
2095
- execute_command "deploy/build_qa_artifact"
2096
- else
2097
- [
2098
- "docker-compose build web",
2099
- "docker-compose run -w $PWD -u root -e MIX_ENV=qa --entrypoint /bin/sh web \
2100
- '-c' 'mix local.hex --force && mix hex.info && \
2101
- mix deps.get && mix compile && mix deps.compile && \
2102
- cd assets && \
2103
- rm -rf node_modules && \
2104
- yarn --cache-folder ~/.cache/yarn && \
2105
- sysconfcpus -n 2 ./node_modules/.bin/webpack --mode production && \
2106
- cd .. && \
2107
- mix phx.digest && \
2108
- rm -rf _build/qa/rel/ && \
2109
- mix release --env=qa'"
2110
- ].each do |cmd|
2111
- execute_command cmd
2112
- end
2113
- end
2069
+ execute_command "deploy/build_qa_artifact"
2114
2070
 
2115
2071
  cleanup_containers
2116
2072
 
@@ -2180,27 +2136,7 @@ class Release
2180
2136
  exec_step 'cp docker-compose.yml docker-compose-ci.yml'
2181
2137
  exec_step 'prepare-docker-compose --directory borat && cp docker-compose-qainit.yml docker-compose.yml'
2182
2138
 
2183
- if File.exists? 'deploy/build_qa_artifact'
2184
- execute_command "deploy/build_qa_artifact"
2185
- else
2186
- [
2187
- "docker network create borat_network || true",
2188
- "docker-compose build web",
2189
- "docker-compose run -w $PWD -u root -e MIX_ENV=qa --entrypoint /bin/sh web \
2190
- '-c' 'mix local.hex --force && mix hex.info && \
2191
- mix deps.get && \
2192
- cd assets && \
2193
- yarn --cache-folder ~/.cache/yarn && \
2194
- sysconfcpus -n 2 ./node_modules/.bin/webpack -p --config config/webpack.config.prod.js && \
2195
- cd ../ && \
2196
- mix phx.digest && \
2197
- mix compile && mix deps.compile && \
2198
- rm -rf _build/qa/rel/ && \
2199
- mix distillery.release --env=qa'"
2200
- ].each do |cmd|
2201
- execute_command cmd
2202
- end
2203
- end
2139
+ execute_command "deploy/build_qa_artifact"
2204
2140
 
2205
2141
  cleanup_containers
2206
2142
 
@@ -2246,27 +2182,26 @@ class Release
2246
2182
  exec_step 'cp docker-compose.yml docker-compose-ci.yml'
2247
2183
  exec_step 'prepare-docker-compose --directory ermes && cp docker-compose-qainit.yml docker-compose.yml'
2248
2184
 
2249
- [
2250
- "if echo `docker network ls` | grep crash_default; \
2251
- then echo 'crash_default network already existing'; \
2252
- else docker network create crash_default; fi",
2253
- 'docker-compose build web'
2254
- ].each do |cmd|
2255
- execute_command cmd
2256
- end
2257
-
2258
- [ "docker-compose run --rm -w $PWD -u root -e MIX_ENV=qa --entrypoint /bin/sh web \
2259
- '-c' 'mix local.hex --force && mix hex.info && \
2260
- mix deps.get && mix compile && mix deps.compile && \
2261
- mix phx.digest && \
2262
- MIX_ENV=dev mix compile.sms && \
2263
- MIX_ENV=dev mix compile.html && \
2264
- MIX_ENV=dev mix compile.heml && \
2265
- MIX_ENV=dev mix compile.app_notification && \
2266
- rm -rf _build/qa/rel/ && \
2267
- mix release --env=qa'"
2268
- ].each do |cmd|
2269
- execute_command cmd
2185
+ if File.exists? 'deploy/build_qa_artifact'
2186
+ execute_command "deploy/build_qa_artifact"
2187
+ else
2188
+ [
2189
+ "if echo `docker network ls` | grep crash_default; \
2190
+ then echo 'crash_default network already existing'; \
2191
+ else docker network create crash_default; fi",
2192
+ 'docker-compose build web',"docker-compose run --rm -w $PWD -u root -e MIX_ENV=qa --entrypoint /bin/sh web \
2193
+ '-c' 'mix local.hex --force && mix hex.info && \
2194
+ mix deps.get && mix compile && mix deps.compile && \
2195
+ mix phx.digest && \
2196
+ MIX_ENV=dev mix compile.sms && \
2197
+ MIX_ENV=dev mix compile.html && \
2198
+ MIX_ENV=dev mix compile.heml && \
2199
+ MIX_ENV=dev mix compile.app_notification && \
2200
+ rm -rf _build/qa/rel/ && \
2201
+ mix release --env=qa'"
2202
+ ].each do |cmd|
2203
+ execute_command cmd
2204
+ end
2270
2205
  end
2271
2206
 
2272
2207
  cleanup_containers
@@ -2707,9 +2642,10 @@ class Release
2707
2642
  end
2708
2643
 
2709
2644
  def deploy_starsky_hutch?
2710
- starsky_present = !@projects['starsky'].nil? && !@projects['starsky'].empty? && @projects['starsky']['name'] != 'master' && !@projects['starsky']['default_branch']
2711
- hutch_present = !@projects['hutch'].nil? && !@projects['hutch'].empty? && @projects['hutch']['name'] != 'master' && !@projects['hutch']['default_branch']
2712
- starsky_present || hutch_present
2645
+ true
2646
+ #starsky_present = !@projects['starsky'].nil? && !@projects['starsky'].empty? && @projects['starsky']['name'] != 'master' && !@projects['starsky']['default_branch']
2647
+ #hutch_present = !@projects['hutch'].nil? && !@projects['hutch'].empty? && @projects['hutch']['name'] != 'master' && !@projects['hutch']['default_branch']
2648
+ #starsky_present || hutch_present
2713
2649
  end
2714
2650
 
2715
2651
  def get_pyxis_version(deploy_id)
@@ -2925,36 +2861,40 @@ class Release
2925
2861
  (Time.now.to_i.to_s[-4..-1].to_i + Random.rand(40000)).to_s
2926
2862
  end
2927
2863
 
2928
- def launch_marley(ip_address, prima_hostname, borat_hostname)
2929
- resp = describe_stack_resource('batch-job-marley', 'JobDefinition')
2864
+ def launch_mimo(env_hash)
2865
+ resp = describe_stack_resource('batch-job-mimo', 'JobDefinition')
2930
2866
 
2931
2867
  @batch.submit_job({
2932
- job_name: "marley-#{@dns_record_identifier}", # required
2868
+ job_name: "mimo-#{@dns_record_identifier}", # required
2933
2869
  job_queue: "tools-production", # required
2934
2870
  job_definition: resp.stack_resource_detail.physical_resource_id, # required
2935
2871
  container_overrides: {
2936
2872
  environment: [
2937
2873
  {
2938
- name: 'PRIMA_URL',
2939
- value: "https://#{prima_hostname}/?superprima"
2874
+ name: 'ENV_HASH',
2875
+ value: env_hash
2940
2876
  },
2941
2877
  {
2942
- name: 'PRIMA_IP',
2943
- value: ip_address
2878
+ name: 'APP_ENV',
2879
+ value: 'qa'
2880
+ },
2881
+ {
2882
+ name: 'CYPRESS_BASE_URL',
2883
+ value: "https://hutch-#{env_hash}.qa.colaster.com"
2944
2884
  },
2945
2885
  {
2946
- name: 'PROJECTS_JSON',
2947
- value: @projects.to_json
2886
+ name: 'CYPRESS_PEANO_BASE_URL',
2887
+ value: "http://peano-#{env_hash}.qa.colaster.com:10039/quotation"
2948
2888
  },
2949
2889
  {
2950
- name: 'BACKOFFICE_URL',
2951
- value: "https://#{borat_hostname}"
2890
+ name: 'QA_NAME',
2891
+ value: @git_branch
2952
2892
  }
2953
2893
  ]
2954
2894
  }
2955
2895
  })
2956
2896
 
2957
- output "Marley lanciato con successo!\n".green
2897
+ output "Mimo lanciato con successo!\n".green
2958
2898
  end
2959
2899
 
2960
2900
  def get_currently_deployed_version(stack_name)
data/bin/twig-update-ami CHANGED
@@ -29,8 +29,8 @@ class TwigUpdateAmi
29
29
  Dir.chdir 'ami'
30
30
  update_instance_name(ami_id, ami_name, ami_description, ami_template)
31
31
  output 'running packer update (this could take some time)'.light_green
32
- new_ami_id = update_packer(ami_template)
33
- # new_ami_id = 'ami-000e38f3a919824ae'
32
+ new_ami_id = update_packer(ami_template, env)
33
+ # new_ami_id = 'ami-0278219494e19b969'
34
34
  Dir.chdir '..'
35
35
  stop_if(new_ami_id.to_s.empty?, 'Failed to generate AMI!'.red)
36
36
  output "new ami id: #{new_ami_id}"
@@ -50,33 +50,28 @@ class TwigUpdateAmi
50
50
  if stack.include?('qa')
51
51
  output "skipping stack #{stack} because is a qa"
52
52
  next
53
- elsif stack.include?('batch')
54
- stack_parameters = update_stack_parameters(get_stack_parameters(stack),
55
- [
56
- { parameter_key: 'AMIID', parameter_value: new_ami_id }
57
- ]
58
- )
59
- update_stack(stack, get_stack_template(stack), stack_parameters)
60
- elsif stack.include?('fleet')
53
+ else
61
54
  stack_tags = tags_to_hashes(get_stack_tags(stack))
62
55
  stack_tags['TemplateVersion'] = stack_tags['TemplateVersion'].to_i + 1
63
56
 
64
- stack_parameters = update_stack_parameters(get_stack_parameters(stack),
65
- [
66
- { parameter_key: 'AMIID', parameter_value: new_ami_id },
67
- { parameter_key: 'DesiredCapacity', parameter_value: get_desired_capacity(stack).to_s },
68
- { parameter_key: 'TemplateVersion', parameter_value: stack_tags['TemplateVersion'].to_s }
69
- ]
70
- )
57
+ if stack.include?('batch')
58
+ stack_parameters = update_stack_parameters(get_stack_parameters(stack),
59
+ [
60
+ { parameter_key: 'AMIID', parameter_value: new_ami_id },
61
+ { parameter_key: 'TemplateVersion', parameter_value: stack_tags['TemplateVersion'].to_s }
62
+ ]
63
+ )
64
+ else
65
+ stack_parameters = update_stack_parameters(get_stack_parameters(stack),
66
+ [
67
+ { parameter_key: 'AMIID', parameter_value: new_ami_id },
68
+ { parameter_key: 'DesiredCapacity', parameter_value: get_desired_capacity(stack).to_s },
69
+ { parameter_key: 'TemplateVersion', parameter_value: stack_tags['TemplateVersion'].to_s }
70
+ ]
71
+ )
72
+ end
73
+
71
74
  update_stack(stack, get_stack_template(stack), stack_parameters, hashes_to_tags(stack_tags))
72
- else # autoscaling group normali come ania-tools
73
- stack_parameters = update_stack_parameters(get_stack_parameters(stack),
74
- [
75
- { parameter_key: 'AMIID', parameter_value: new_ami_id },
76
- { parameter_key: 'DesiredCapacity', parameter_value: get_desired_capacity(stack).to_s }
77
- ]
78
- )
79
- update_stack(stack, get_stack_template(stack), stack_parameters)
80
75
  end
81
76
  end
82
77
 
@@ -149,8 +144,8 @@ class TwigUpdateAmi
149
144
  end
150
145
  end
151
146
 
152
- def update_packer(json_filename)
153
- execute_command "AWS_MAX_ATTEMPTS=90 AWS_POLL_DELAY_SECONDS=60 packer build -var datadog_apikey=`biscuit get -f ../configs/secrets/common.yml common_production_apikey_datadog` -var github_token=`biscuit get -f ../configs/secrets/common.yml common_private_repo_github_token` -var drone_key=\"`biscuit get -f ../configs/secrets/common.yml drone_license_key`\" -machine-readable ./#{json_filename} | tee build.log"
147
+ def update_packer(json_filename, env)
148
+ execute_command "AWS_MAX_ATTEMPTS=90 AWS_POLL_DELAY_SECONDS=60 packer build -var datadog_apikey=`biscuit get -f ../configs/secrets/common.yml common_production_apikey_datadog` -var github_token=`biscuit get -f ../configs/secrets/common.yml common_private_repo_github_token` -var drone_key=\"`biscuit get -f ../configs/secrets/common.yml drone_license_key`\" -var env=#{env} -machine-readable ./#{json_filename} | tee build.log"
154
149
  `grep 'artifact,0,id' build.log | cut -d, -f6 | cut -d: -f2`.sub(/\n/, '')
155
150
  end
156
151
 
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: prima-twig
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.62.14
4
+ version: 0.62.15
5
5
  platform: ruby
6
6
  authors:
7
7
  - Matteo Giachino
@@ -14,7 +14,7 @@ authors:
14
14
  autorequire:
15
15
  bindir: bin
16
16
  cert_chain: []
17
- date: 2020-03-04 00:00:00.000000000 Z
17
+ date: 2020-03-16 00:00:00.000000000 Z
18
18
  dependencies:
19
19
  - !ruby/object:Gem::Dependency
20
20
  name: aws-sdk-autoscaling
@@ -326,7 +326,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
326
326
  - !ruby/object:Gem::Version
327
327
  version: '0'
328
328
  requirements: []
329
- rubygems_version: 3.0.1
329
+ rubygems_version: 3.0.3
330
330
  signing_key:
331
331
  specification_version: 4
332
332
  summary: The Prima twig toolbelt