kennel 1.58.1 → 1.59.1

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: ef549d9d676c1901f184a65c88313dd7ad3146390f1801ae530b4028d280e60e
4
- data.tar.gz: 0ff01feab2d2da87bc51b6f5bfb5ff8a2a947a950214b627ca09c81ca89ea347
3
+ metadata.gz: 3bfb9110f28e8b361953fcdc0269511e5646e5df1ceb927bf575bd68b39504dc
4
+ data.tar.gz: ec095c27801cdaa4d608ca0cacc5f481ada53dfe917b574fdd1536419a6d31dd
5
5
  SHA512:
6
- metadata.gz: 1ba3c81e8c16f0fe11bc91b29bc40f9086cba82c5fa18cda2f0f00500c0b7a3a85d3bddf405f3081b718711040c3891d81008a364668af6c98eb343da05e7515
7
- data.tar.gz: dd8c7dbed5e32a3c8e690fd42e6db8252bfd30727398b933d9013d9d7ce4a3da5f997d8c8ade339aac4969eecf5f22c8b520b813bc17a489a6ddb126ff8f9588
6
+ metadata.gz: 1aebb0f3c5954ddc7167221290a376dbdd05457b7b2a3892ccd569d27760ed9a9e5b6c6b35ff4bb8f45b1e431a8d2da096b26a381073cb3788f5ea395027f31a
7
+ data.tar.gz: 5aef7d0e9e2447271eec6c5ae215ef998238535627bf41cdd4034f9f0b83650816981380e6da85998de4d81fac8b70a823e2b8914499a1172eab0522f7e6f48e
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
data/lib/kennel.rb CHANGED
@@ -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
data/lib/kennel/api.rb CHANGED
@@ -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
 
@@ -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
 
data/lib/kennel/syncer.rb CHANGED
@@ -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
 
data/lib/kennel/tasks.rb CHANGED
@@ -9,7 +9,7 @@ module Kennel
9
9
  class << self
10
10
  def abort(message = nil)
11
11
  Kennel.err.puts message if message
12
- raise SystemExit, message
12
+ raise SystemExit.new(1), message
13
13
  end
14
14
  end
15
15
  end
@@ -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
@@ -1,4 +1,4 @@
1
1
  # frozen_string_literal: true
2
2
  module Kennel
3
- VERSION = "1.58.1"
3
+ VERSION = "1.59.1"
4
4
  end
data/template/Readme.md CHANGED
@@ -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.1
4
+ version: 1.59.1
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-11-25 00:00:00.000000000 Z
11
+ date: 2019-12-12 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: faraday