Skip to content

Commit

Permalink
Support terraform config generation from auditctx template
Browse files Browse the repository at this point in the history
  • Loading branch information
zzaakiirr committed Nov 7, 2024
1 parent 4b762a8 commit 8b3226e
Show file tree
Hide file tree
Showing 7 changed files with 104 additions and 4 deletions.
4 changes: 2 additions & 2 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -18,5 +18,5 @@
/spec/dummy/.controlplane/controlplane*-tmp-*.yml

# Generated configs
terraform/
.controlplane/
/terraform/
/.controlplane/
23 changes: 23 additions & 0 deletions lib/core/terraform_config/audit_context.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# frozen_string_literal: true

module TerraformConfig
class AuditContext < Base
attr_reader :name, :description, :tags

def initialize(name:, description: nil, tags: nil)
super()

@name = name
@description = description
@tags = tags
end

def to_tf
block :resource, :cpln_audit_context, name do
argument :name, name
argument :description, description, optional: true
argument :tags, tags, optional: true
end
end
end
end
13 changes: 11 additions & 2 deletions lib/core/terraform_config/generator.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

module TerraformConfig
class Generator # rubocop:disable Metrics/ClassLength
SUPPORTED_TEMPLATE_KINDS = %w[gvc secret identity policy volumeset workload].freeze
SUPPORTED_TEMPLATE_KINDS = %w[gvc secret identity policy volumeset workload auditctx].freeze
WORKLOAD_SPEC_KEYS = %i[
type
containers
Expand Down Expand Up @@ -44,6 +44,8 @@ def filename
"gvc.tf"
when "workload"
"#{template[:name]}.tf"
when "auditctx"
"audit_contexts.tf"
else
"#{kind.pluralize}.tf"
end
Expand All @@ -54,8 +56,11 @@ def tf_config
end

def config_class
if kind == "volumeset"
case kind
when "volumeset"
TerraformConfig::VolumeSet
when "auditctx"
TerraformConfig::AuditContext
else
TerraformConfig.const_get(kind.capitalize)
end
Expand Down Expand Up @@ -104,6 +109,10 @@ def volumeset_config_params
template.slice(:name, :description, :tags).merge(gvc: gvc).merge(specs)
end

def auditctx_config_params
template.slice(:name, :description, :tags)
end

def workload_config_params
template
.slice(:name, :description, :tags)
Expand Down
1 change: 1 addition & 0 deletions spec/command/terraform/generate_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
maintenance
maintenance_envs
maintenance-with-external-image
audit_contexts
].freeze

describe Command::Terraform::Generate do
Expand Down
34 changes: 34 additions & 0 deletions spec/core/terraform_config/audit_context_spec.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
# frozen_string_literal: true

require "spec_helper"

describe TerraformConfig::AuditContext do
let(:config) { described_class.new(**options) }

describe "#to_tf" do
subject(:generated) { config.to_tf }

let(:options) do
{
name: "audit-context-name",
description: "audit context description",
tags: { "tag1" => "true", "tag2" => "value" }
}
end

it "generates correct config" do
expect(generated).to eq(
<<~EXPECTED
resource "cpln_audit_context" "audit-context-name" {
name = "audit-context-name"
description = "audit context description"
tags = {
tag1 = "true"
tag2 = "value"
}
}
EXPECTED
)
end
end
end
28 changes: 28 additions & 0 deletions spec/core/terraform_config/generator_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -253,6 +253,34 @@
end
end

context "when template's kind is auditctx" do
let(:template) do
{
"kind" => "auditctx",
"name" => "audit-context-name",
"description" => "audit context description",
"tags" => { "tag1" => "tag1_value", "tag2" => "tag2_value" }
}
end

it "generates correct terraform config and filename for it", :aggregate_failures do
expected_filename = "audit_contexts.tf"

tf_configs = generator.tf_configs
expect(tf_configs.count).to eq(1)

filenames = tf_configs.keys
expect(filenames).to contain_exactly(expected_filename)

tf_config = tf_configs[expected_filename]
expect(tf_config).to be_an_instance_of(TerraformConfig::AuditContext)

expect(tf_config.name).to eq("audit-context-name")
expect(tf_config.description).to eq("audit context description")
expect(tf_config.tags).to eq(tag1: "tag1_value", tag2: "tag2_value")
end
end

context "when template's kind is workload" do
let(:template) do
{
Expand Down
5 changes: 5 additions & 0 deletions spec/dummy/.controlplane/templates/audit_context.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
kind: auditctx
name: audit-context-name
description: audit context description
tags:
tag1: value1

0 comments on commit 8b3226e

Please sign in to comment.