Skip to content

Commit

Permalink
feat: setter can now takes maps
Browse files Browse the repository at this point in the history
  • Loading branch information
LeCrabe committed Apr 17, 2024
1 parent 5f823d9 commit 503b650
Show file tree
Hide file tree
Showing 8 changed files with 164 additions and 155 deletions.
24 changes: 10 additions & 14 deletions pkg/helper/provider_block.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@ package helper

// Provider structur
type Provider struct {
Provider string
Organisation string
provider string
organisation string
}

// New function type that accepts pointer to Provider
Expand All @@ -14,20 +14,15 @@ type ProviderOption func(*Provider)
// - desc: Build a new Provider and apply specifics ProviderOption functions
// - args: provider name, ProviderOption function
// - return: pointer to Provider
func NewProvider(provider string, opts ...ProviderOption) *Provider {
func NewProvider(providerName string) *Provider {
// default values
const (
defaultOrganisation = ""
)

p := &Provider{
Provider: provider,
Organisation: defaultOrganisation,
}

// ProviderOption functions
for _, opt := range opts {
opt(p)
provider: providerName,
organisation: defaultOrganisation,
}

return p
Expand All @@ -38,7 +33,7 @@ func NewProvider(provider string, opts ...ProviderOption) *Provider {
// - args: new organisation name
// - return: pointer to Provider
func (p *Provider) SetOrganisation(orgName string) *Provider {
p.Organisation = orgName
p.organisation = orgName
return p
}

Expand All @@ -47,8 +42,9 @@ func (p *Provider) SetOrganisation(orgName string) *Provider {
// - args: none
// - return: string
func (p *Provider) String() string {
s := `provider "` + p.Provider + `" {
organisation = "` + p.Organisation + `"
}`
s := `provider "` + p.provider + `" {
organisation = "` + p.organisation + `"
}
`
return s
}
5 changes: 2 additions & 3 deletions pkg/helper/provider_block_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,10 @@ func TestProvider_String(t *testing.T) {
fields *Provider
want string
}{
// TODO: Add test cases.

{name: "test1", fields: NewProvider("clevercloud").SetOrganisation("clevercloud"), want: `provider "clevercloud" {
organisation = "clevercloud"
}`},
}
`},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
Expand Down
156 changes: 78 additions & 78 deletions pkg/helper/ressource_block.go
Original file line number Diff line number Diff line change
@@ -1,15 +1,19 @@
package helper

import (
"reflect"
"sort"
"strconv"
"strings"

"go.clever-cloud.com/terraform-provider/pkg"
)

type Ressource struct {
Ressource string
Name string
StringValues map[string]string
IntValues map[string]int
ressourceType string
ressourceName string
keyValues map[string]any
blockValues map[string]any
}

// New function type that accepts pointer to Ressource
Expand All @@ -18,31 +22,15 @@ type RessourceOption func(*Ressource)

// Ressource constructor:
// - desc: Build a new Ressource and apply specifics RessourceOption functions
// - args: Ressource name, RessourceOption function
// - args: Ressource type and ressource name, RessourceOption function
// - return: pointer to Ressource
func NewRessource(ressource string, opts ...RessourceOption) *Ressource {
// default values
const (
defaultName = ""
defaultRegion = "par"
dafaultMinInstances = 1
defaultMaxInstances = 2
defaultSmallestFlavor = "XS"
defaultBiggestFlavor = "M"
)
func NewRessource(ressourceType, ressourceName string, opts ...RessourceOption) *Ressource {

var r Ressource
r.Ressource = ressource
r.Name = defaultName
r.StringValues = map[string]string{
"region": defaultRegion,
"smallest_flavor": defaultSmallestFlavor,
"biggest_flavor": defaultBiggestFlavor,
}
r.IntValues = map[string]int{
"min_instance_count": dafaultMinInstances,
"max_instance_count": defaultMaxInstances,
}
r.ressourceType = ressourceType
r.ressourceName = ressourceName
r.keyValues = map[string]any{}
r.blockValues = map[string]any{}

// RessourceOption functions
for _, opt := range opts {
Expand All @@ -52,76 +40,88 @@ func NewRessource(ressource string, opts ...RessourceOption) *Ressource {
return &r
}

// Name value setter:
// - desc: concatenate function that set Ressource.Name then return Ressource
// - args: new name
// unit keyValues setter:
// - desc: set/add only one key: value to keyvalues field of a Ressource then return the Ressource
// - args: key + value
// - return: pointer to Ressource
func (r *Ressource) SetName(newName string) *Ressource {
r.Name = newName
func (r *Ressource) SetOneValue(key string, value any) *Ressource {
r.keyValues[key] = value
return r
}

// String values setter:
// - desc: set/add key: value to the string values map of a Ressource then return the Ressource
// - args: key + value
// - return: pointer to Ressource
func (p *Ressource) SetStringValues(key, value string) *Ressource {
p.StringValues[key] = value
return p
// keyValues setter:
// - desc: set/add key: value to keyValues field of a Ressource then return the Ressource
// - args: map of string key + value
// - return: RessourceOption functions
func SetKeyValues(newMap map[string]any) RessourceOption {
return func(r *Ressource) {
for key, value := range newMap {
r.keyValues[key] = value
}
}
}

// Integer values setter:
// - desc: set/add key: value to the int values map of a Ressource then return the Ressource
// - args: key + value
// - return: pointer to Ressource
func (p *Ressource) SetIntValues(key string, value int) *Ressource {
p.IntValues[key] = value
return p
// blockValues setter:
// - desc: set/add key: value to kblockValues field of a Ressource then return the Ressource
// - args: map of string key + value
// - return: RessourceOption functions
func SetBlockValues(blockName string, newMap map[string]any) RessourceOption {
return func(r *Ressource) {
r.blockValues[blockName] = newMap
}
}

// Ressource block
// - desc: chained function that stringify Ressource into a terraform block
// - args: none
// - return: string
func (p *Ressource) String() string {
s := `ressource "` + p.Ressource + `" "` + p.Name + `" {
name = "` + p.Name + `"
func (r *Ressource) String() string {
s := `resource "` + r.ressourceType + `" "` + r.ressourceName + `" {
`
// check StringValues not empty
if len(p.StringValues) != 0 {
// sort StringValues keys
tmp := make([]string, 0, len(p.StringValues))
for k := range p.StringValues {
tmp = append(tmp, k)
}
sort.Strings(tmp)

// create StringValues block
sstring := ``
for _, k := range tmp {
sstring += ` ` + k + ` = "` + p.StringValues[k] + `"
// create keyValues block
s = map_String(r.keyValues, s, ` `, ` =`)
// create blockValues block
s = map_String(r.blockValues, s, ` `, ``)

// close s
s += `}
`
}
s += sstring

return s
}

func map_String(m map[string]any, s, tab, separator string) string {
// sort keyValues keys
valuesKeys := make([]string, 0, len(m))
for k := range m {
valuesKeys = append(valuesKeys, k)
}
// check IntValues not empty
if len(p.IntValues) != 0 {
// sort IntValues keys
tmp := make([]string, 0, len(p.IntValues))
for k := range p.IntValues {
tmp = append(tmp, k)
}
sort.Strings(tmp)
sort.Strings(valuesKeys)

// create IntValues block
sint := ``
for _, k := range tmp {
sint += ` ` + k + ` = ` + strconv.Itoa(p.IntValues[k]) + `
// create keyValues block
s = pkg.Reduce(valuesKeys, s, func(acc, key string) string {
switch c_type := m[key].(type) {
case string:
var_tmp := m[key].(string)
return acc + tab + key + ` = "` + strings.ReplaceAll(var_tmp, "\"", "\\\"") + `"
`
case int:
return acc + tab + key + ` = ` + strconv.Itoa(m[key].(int)) + `
`
case bool:
return acc + tab + key + ` = ` + strconv.FormatBool(m[key].(bool)) + `
`
case map[string]any:
acc := acc + tab + key + separator + ` {
`
return map_String(m[key].(map[string]any), acc, ` `, separator) + tab + `}
`
default:
return acc + `// Type ` + reflect.TypeOf(c_type).String() + ` of key "` + key + `" not considered yet
`
}
s += sint
}
// close s
s += `}`
})

return s
}
59 changes: 41 additions & 18 deletions pkg/helper/ressource_block_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,24 +8,47 @@ func TestRessource_String(t *testing.T) {
fields *Ressource
want string
}{
// TODO: Add test cases.

{name: "test1", fields: NewRessource("clevercloud").SetName("test1"), want: `ressource "clevercloud" "test1" {
name = "test1"
biggest_flavor = "M"
region = "par"
smallest_flavor = "XS"
max_instance_count = 2
min_instance_count = 1
}`},
{name: "test2", fields: NewRessource("clevercloud_python").SetName("test2").SetIntValues("min_instance_count", 3), want: `ressource "clevercloud_python" "test2" {
name = "test2"
biggest_flavor = "M"
region = "par"
smallest_flavor = "XS"
max_instance_count = 2
min_instance_count = 3
}`},
{name: "test1",
fields: NewRessource("clevercloud", "test1"),
want: `resource "clevercloud" "test1" {
}
`},
{
name: "test2",
fields: NewRessource("clevercloud_python", "test2").
SetOneValue("biggest_flavor", "XXL").
SetOneValue("test", 3),
want: `resource "clevercloud_python" "test2" {
biggest_flavor = "XXL"
test = 3
}
`},
{name: "test3",
fields: NewRessource(
"clevercloud_python",
"test3",
SetKeyValues(map[string]any{
"region": "ici",
"teststring": "smt",
"min_instance_count": 0,
"testint": 12,
"map": map[string]any{"test_string": "string", "test_int": 42}}),
SetBlockValues("testblock", map[string]any{"test_string": "string", "test_int": 42})),
want: `resource "clevercloud_python" "test3" {
map = {
test_int = 42
test_string = "string"
}
min_instance_count = 0
region = "ici"
testint = 12
teststring = "smt"
testblock {
test_int = 42
test_string = "string"
}
}
`},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
Expand Down
3 changes: 0 additions & 3 deletions pkg/resources/python/provider_test_block.tf

This file was deleted.

Loading

0 comments on commit 503b650

Please sign in to comment.