kennel 1.58.2 → 1.59.2

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 27642045f1b97eac7f2a3184ccc0988a090ac9d4ad3d530120dc614a2b4e5670
4
- data.tar.gz: 1f7d6b79d90b4fd1a5a76194af9a5c856920b190fbe0aa50b86499414976003e
3
+ metadata.gz: da2bef045b7b3b70aaf46ddf1254d31ea43fb0821276a05d08ffe1027d7dcd60
4
+ data.tar.gz: ccdcb485de98385ecb58d2aa379550de5c44054b822232b36a678f034593629d
5
5
  SHA512:
6
- metadata.gz: cbd7460160bbb5e65fb1d509a1d0f9eee36229b895591f1555a1e972a2add145646fe24e3956f663bb2b0c501592cdb4a3b52b788d3811210b98a515a0d4658e
7
- data.tar.gz: 2f896e594c59774d29d4273b885a0e4ee7ace8dcad4d3a16621d606a5b64bdb4da5ca75bb2afe52b1a137fe0d14cb46a62aa41c771830c868d3b38019a3881a2
6
+ metadata.gz: 2e4132e556b0eb1a1bf4aaa0a3b7913a1e70f790be3b3226238e6d9d9e2771544b96d665ee668841fd7fa640ac22abd3b2467b91be6d70ca167d01e2af0bd426
7
+ data.tar.gz: fda2c3268e6420c106ded560ca5fb59dc97fe783e385d2295588e2cabc3b367f0e1375a48355dbfd4968e19743ebcce60136bd2ba9dc483c7024326abee12828
data/Readme.md CHANGED
@@ -45,6 +45,7 @@ Keep datadog monitors/dashboards/etc in version control, avoid chaotic managemen
45
45
  - copy any `API Key` and add it to `.env` as `DATADOG_API_KEY`
46
46
  - find or create (check last page) your personal "Application Key" and add it to `.env` as `DATADOG_APP_KEY=`
47
47
  - change the `DATADOG_SUBDOMAIN=app` in `.env` to your companies subdomain if you have one
48
+ - verify it works by running `rake plan`, it might show some diff, but should not crash
48
49
  -->
49
50
 
50
51
  ### Adding a team
@@ -29,6 +29,10 @@ require "kennel/models/project"
29
29
  require "kennel/models/team"
30
30
 
31
31
  module Kennel
32
+ MISSING_ID = 1
33
+ class ValidationError < RuntimeError
34
+ end
35
+
32
36
  @out = $stdout
33
37
  @err = $stderr
34
38
 
@@ -68,7 +72,7 @@ module Kennel
68
72
  Progress.progress "Generating" do
69
73
  load_all
70
74
  parts = Models::Project.recursive_subclasses.flat_map do |project_class|
71
- project_class.new.parts
75
+ project_class.new.validated_parts
72
76
  end
73
77
  parts.map(&:tracking_id).group_by { |id| id }.select do |id, same|
74
78
  raise "#{id} is defined #{same.size} times" if same.size != 1
@@ -13,7 +13,22 @@ module Kennel
13
13
  end
14
14
 
15
15
  def list(api_resource, params = {})
16
- request :get, "/api/v1/#{api_resource}", params: params
16
+ if api_resource == "slo"
17
+ raise ArgumentError if params[:limit] || params[:offset]
18
+ limit = 1000
19
+ offset = 0
20
+ all = []
21
+
22
+ loop do
23
+ result = request :get, "/api/v1/#{api_resource}", params: params.merge(limit: limit, offset: offset)
24
+ data = result.fetch(:data)
25
+ all.concat data
26
+ break all if data.size < limit
27
+ offset += limit
28
+ end
29
+ else
30
+ request :get, "/api/v1/#{api_resource}", params: params
31
+ end
17
32
  end
18
33
 
19
34
  def create(api_resource, attributes)
@@ -101,16 +101,16 @@ module Kennel
101
101
  when "uptime"
102
102
  if ids = definition[:monitor_ids]
103
103
  definition[:monitor_ids] = ids.map do |id|
104
- tracking_id?(id) ? resolve_link(id, id_map, force: false) : id
104
+ tracking_id?(id) ? resolve_link(id, id_map) : id
105
105
  end
106
106
  end
107
107
  when "alert_graph"
108
108
  if (id = definition[:alert_id]) && tracking_id?(id)
109
- definition[:alert_id] = resolve_link(id, id_map, force: false).to_s
109
+ definition[:alert_id] = resolve_link(id, id_map).to_s
110
110
  end
111
111
  when "slo"
112
112
  if (id = definition[:slo_id]) && tracking_id?(id)
113
- definition[:slo_id] = resolve_link(id, id_map, force: false).to_s
113
+ definition[:slo_id] = resolve_link(id, id_map).to_s
114
114
  end
115
115
  end
116
116
  end
@@ -105,6 +105,7 @@ module Kennel
105
105
  def resolve_linked_tracking_ids(id_map)
106
106
  if as_json[:type] == "composite"
107
107
  as_json[:query] = as_json[:query].gsub(/%\{(.*?)\}/) do
108
+ # need force here since it validates the id exists
108
109
  resolve_link($1, id_map, force: true)
109
110
  end
110
111
  end
@@ -14,6 +14,18 @@ module Kennel
14
14
  instance_method(method_in_file).source_location.first.sub("#{Bundler.root}/", "")
15
15
  end
16
16
  end
17
+
18
+ def validated_parts
19
+ all = parts
20
+ validate_parts(all)
21
+ all
22
+ end
23
+
24
+ private
25
+
26
+ # hook for users to add custom validations via `prepend`
27
+ def validate_parts(parts)
28
+ end
17
29
  end
18
30
  end
19
31
  end
@@ -13,9 +13,6 @@ module Kennel
13
13
  }.freeze
14
14
  API_LIST_INCOMPLETE = false
15
15
 
16
- class ValidationError < RuntimeError
17
- end
18
-
19
16
  settings :id, :kennel_id
20
17
 
21
18
  class << self
@@ -81,10 +78,19 @@ module Kennel
81
78
 
82
79
  private
83
80
 
84
- def resolve_link(id, id_map, force:)
85
- id_map[id] || begin
86
- message = "Unable to find #{id} in existing monitors (they need to be created first to link them)"
87
- force ? invalid!(message) : Kennel.err.puts(message)
81
+ def resolve_link(id, id_map, force: false)
82
+ found = id_map[id]
83
+ return found if found && found != :new
84
+
85
+ if found == :new
86
+ if force
87
+ invalid! "Monitor #{id} will be created in the current run and can only be used after that"
88
+ else
89
+ Kennel.err.puts "Monitor #{id} will be created in the current run, the next run will link it properly"
90
+ Kennel::MISSING_ID
91
+ end
92
+ else
93
+ invalid! "Unable to find monitor #{id} (does not exist and is not being created by the current run)"
88
94
  end
89
95
  end
90
96
 
@@ -35,7 +35,7 @@ module Kennel
35
35
  description: description,
36
36
  thresholds: thresholds,
37
37
  monitor_ids: monitor_ids,
38
- tags: tags,
38
+ tags: tags.uniq,
39
39
  type: type
40
40
  }
41
41
 
@@ -55,7 +55,7 @@ module Kennel
55
55
 
56
56
  def resolve_linked_tracking_ids(id_map)
57
57
  as_json[:monitor_ids] = as_json[:monitor_ids].map do |id|
58
- id.is_a?(String) ? resolve_link(id, id_map, force: false) || 1 : id
58
+ id.is_a?(String) ? resolve_link(id, id_map) : id
59
59
  end
60
60
  end
61
61
 
@@ -195,6 +195,7 @@ module Kennel
195
195
 
196
196
  def resolve_linked_tracking_ids(actual)
197
197
  map = actual.each_with_object({}) { |a, lookup| lookup[tracking_id(a)] = a.fetch(:id) }
198
+ @expected.each { |e| map[e.tracking_id] ||= :new }
198
199
  @expected.each { |e| e.resolve_linked_tracking_ids(map) }
199
200
  end
200
201
 
@@ -18,7 +18,7 @@ end
18
18
  namespace :kennel do
19
19
  desc "Ensure there are no uncommited changes that would be hidden from PR reviewers"
20
20
  task no_diff: :generate do
21
- result = `git status --porcelain`.strip
21
+ result = `git status --porcelain generated/`.strip
22
22
  Kennel::Tasks.abort "Diff found:\n#{result}\nrun `rake generate` and commit the diff to fix" unless result == ""
23
23
  Kennel::Tasks.abort "Error during diffing" unless $CHILD_STATUS.success?
24
24
  end
@@ -45,8 +45,7 @@ namespace :kennel do
45
45
  end
46
46
 
47
47
  if bad.any?
48
- subdomain = ENV["DATADOG_SUBDOMAIN"]
49
- url = (subdomain ? "https://zendesk.datadoghq.com" : "") + "/account/settings"
48
+ url = Kennel::Utils.path_to_url "/account/settings"
50
49
  puts "Invalid mentions found, either ignore them by adding to `KNOWN` env var or add them via #{url}"
51
50
  bad.each { |f, v| puts "Invalid mention #{v} in monitor message of #{f}" }
52
51
  Kennel::Tasks.abort
@@ -1,4 +1,4 @@
1
1
  # frozen_string_literal: true
2
2
  module Kennel
3
- VERSION = "1.58.2"
3
+ VERSION = "1.59.2"
4
4
  end
@@ -28,6 +28,7 @@ Keep datadog monitors/dashboards/etc in version control, avoid chaotic managemen
28
28
  - copy any `API Key` and add it to `.env` as `DATADOG_API_KEY`
29
29
  - find or create (check last page) your personal "Application Key" and add it to `.env` as `DATADOG_APP_KEY=`
30
30
  - change the `DATADOG_SUBDOMAIN=app` in `.env` to your companies subdomain if you have one
31
+ - verify it works by running `rake plan`, it might show some diff, but should not crash
31
32
 
32
33
  ### Adding a team
33
34
 
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: kennel
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.58.2
4
+ version: 1.59.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Michael Grosser
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2019-12-04 00:00:00.000000000 Z
11
+ date: 2019-12-18 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: faraday