Skip to content

Commit

Permalink
s/whitelist/allowlist
Browse files Browse the repository at this point in the history
  • Loading branch information
timothysmith0609 committed Dec 11, 2023
1 parent b87c0c0 commit b474ab2
Show file tree
Hide file tree
Showing 7 changed files with 23 additions and 19 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
## next

# 3.4.0

- Use `prune-allowlist` instead of `prune-whitelist`. This change requires kubernetes 1.26 and higher. [#940](https://github.com/Shopify/krane/pull/940)

## 3.3.0

*Enhancements*
Expand Down
6 changes: 3 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -89,9 +89,9 @@ Krane provides support for official upstream supported versions [Kubernetes](htt
| 1.20 | No | 2.4.9 |
| 1.21 | No | 2.4.9 |
| 1.22 | No | 3.0.1 |
| 1.23 | Yes | -- |
| 1.24 | Yes | -- |
| 1.25 | No | -- |
| 1.23 | Yes | 3.3.0 |
| 1.24 | Yes | 3.3.0 |
| 1.25 | No | 3.3.0 |
| 1.26 | Yes | -- |
| 1.27 | Yes | -- |

Expand Down
4 changes: 2 additions & 2 deletions lib/krane/deploy_task.rb
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ def predeploy_sequence
Hash[before_crs + crs + after_crs]
end

def prune_whitelist
def prune_allowlist
cluster_resource_discoverer.prunable_resources(namespaced: true)
end

Expand Down Expand Up @@ -192,7 +192,7 @@ def run!(verify_result: true, prune: true)

def resource_deployer
@resource_deployer ||= Krane::ResourceDeployer.new(task_config: @task_config,
prune_whitelist: prune_whitelist, global_timeout: @global_timeout,
prune_allowlist: prune_allowlist, global_timeout: @global_timeout,
selector: @selector, statsd_tags: statsd_tags, current_sha: @current_sha)
end

Expand Down
4 changes: 2 additions & 2 deletions lib/krane/global_deploy_task.rb
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ def run!(verify_result: true, prune: true)

def deploy!(resources, verify_result, prune)
resource_deployer = ResourceDeployer.new(task_config: @task_config,
prune_whitelist: prune_whitelist, global_timeout: @global_timeout,
prune_allowlist: prune_allowlist, global_timeout: @global_timeout,
selector: @selector, statsd_tags: statsd_tags)
resource_deployer.deploy!(resources, verify_result, prune)
end
Expand Down Expand Up @@ -194,7 +194,7 @@ def kubectl
@kubectl ||= Kubectl.new(task_config: @task_config, log_failure_by_default: true)
end

def prune_whitelist
def prune_allowlist
cluster_resource_discoverer.prunable_resources(namespaced: false)
end

Expand Down
10 changes: 5 additions & 5 deletions lib/krane/resource_deployer.rb
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,9 @@ class ResourceDeployer
delegate :logger, to: :@task_config
attr_reader :statsd_tags

def initialize(task_config:, prune_whitelist:, global_timeout:, current_sha: nil, selector:, statsd_tags:)
def initialize(task_config:, prune_allowlist:, global_timeout:, current_sha: nil, selector:, statsd_tags:)
@task_config = task_config
@prune_whitelist = prune_whitelist
@prune_allowlist = prune_allowlist
@global_timeout = global_timeout
@current_sha = current_sha
@selector = selector
Expand Down Expand Up @@ -102,7 +102,7 @@ def deploy_resources(resources, prune: false, verify:, record_summary: true)
# Apply can be done in one large batch, the rest have to be done individually
applyables, individuals = resources.partition { |r| r.deploy_method == :apply }
# Prunable resources should also applied so that they can be pruned
pruneable_types = @prune_whitelist.map { |t| t.split("/").last }
pruneable_types = @prune_allowlist.map { |t| t.split("/").last }
applyables += individuals.select { |r| pruneable_types.include?(r.type) && !r.deploy_method_override }

individuals.each do |individual_resource|
Expand Down Expand Up @@ -147,14 +147,14 @@ def apply_all(resources, prune, dry_run: false)
r.deploy_started_at = Time.now.utc unless dry_run
end
command.push("-f", tmp_dir)
if prune && @prune_whitelist.present?
if prune && @prune_allowlist.present?
command.push("--prune")
if @selector
command.push("--selector", @selector.to_s)
else
command.push("--all")
end
@prune_whitelist.each { |type| command.push("--prune-whitelist=#{type}") }
@prune_allowlist.each { |type| command.push("--prune-allowlist=#{type}") }
end

command.push(kubectl.dry_run_flag) if dry_run
Expand Down
2 changes: 1 addition & 1 deletion lib/krane/version.rb
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# frozen_string_literal: true
module Krane
VERSION = "3.3.0"
VERSION = "3.4.0"
end
12 changes: 6 additions & 6 deletions test/unit/krane/resource_deployer_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,18 +7,18 @@ def test_deploy_prune_builds_whitelist
whitelist_kind = "fake_kind"
resource = build_mock_resource
Krane::Kubectl.any_instance.expects(:run).with do |*args|
args.include?("--prune-whitelist=#{whitelist_kind}")
args.include?("--prune-allowlist=#{whitelist_kind}")
end.returns(["", "", stub(success?: true)])
resource_deployer(kubectl_times: 0, prune_whitelist: [whitelist_kind]).deploy!([resource], false, true)
resource_deployer(kubectl_times: 0, prune_allowlist: [whitelist_kind]).deploy!([resource], false, true)
end

def test_deploy_no_prune_doesnt_prune
whitelist_kind = "fake_kind"
resource = build_mock_resource
Krane::Kubectl.any_instance.expects(:run).with do |*args|
!args.include?("--prune-whitelist=#{whitelist_kind}")
!args.include?("--prune-allowlist=#{whitelist_kind}")
end.returns(["", "", stub(success?: true)])
resource_deployer(kubectl_times: 0, prune_whitelist: [whitelist_kind]).deploy!([resource], false, false)
resource_deployer(kubectl_times: 0, prune_allowlist: [whitelist_kind]).deploy!([resource], false, false)
end

def test_deploy_verify_false_message
Expand Down Expand Up @@ -84,13 +84,13 @@ def test_predeploy_priority_resources_respects_empty_pre_deploy_list

private

def resource_deployer(kubectl_times: 1, prune_whitelist: [])
def resource_deployer(kubectl_times: 1, prune_allowlist: [])
unless kubectl_times == 0
runless = build_runless_kubectl
Krane::Kubectl.expects(:new).returns(runless).times(kubectl_times)
end
@deployer = Krane::ResourceDeployer.new(current_sha: 'test-sha',
statsd_tags: [], task_config: task_config, prune_whitelist: prune_whitelist,
statsd_tags: [], task_config: task_config, prune_allowlist: prune_allowlist,
global_timeout: 1, selector: nil)
end

Expand Down

0 comments on commit b474ab2

Please sign in to comment.