mirror of
https://github.com/bpg/terraform-provider-proxmox.git
synced 2025-07-02 03:22:59 +00:00
* cleanup 1
* continue refactoring
* more refactoring
* move VMs under nodes
* move container and other apis under nodes
* cleanups
* enabled revive.exported linter & add comments to exported stuff
* enable godot linter
* enable wsl linter
* enable thelper linter
* enable govet linter
* cleanup after rebase
* cleanup after rebase
* extract SSH ops into a separate interface
* fix linter error
* move ssh code to its own package
* cleaning up VirtualEnvironmentClient receivers
* on the finish line
* not sure what else I forgot... 🤔
* fix ssh connection and upload
* renaming client interfaces
* final cleanups
73 lines
1.8 KiB
Go
73 lines
1.8 KiB
Go
/*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at https://mozilla.org/MPL/2.0/.
|
|
*/
|
|
|
|
package firewall
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/bpg/terraform-provider-proxmox/proxmoxtf/structure"
|
|
)
|
|
|
|
// TestRuleInstantiation tests whether the Rules instance can be instantiated.
|
|
func TestRuleInstantiation(t *testing.T) {
|
|
t.Parallel()
|
|
require.NotNilf(t, Rules(), "Cannot instantiate Rules")
|
|
}
|
|
|
|
// TestRuleSchema tests the Rules Schema.
|
|
func TestRuleSchema(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
rulesSchema := Rules().Schema
|
|
|
|
structure.AssertRequiredArguments(t, rulesSchema, []string{
|
|
MkRule,
|
|
})
|
|
|
|
structure.AssertOptionalArguments(t, rulesSchema, []string{
|
|
mkSelectorVMID,
|
|
mkSelectorNodeName,
|
|
})
|
|
|
|
ruleSchema := structure.AssertNestedSchemaExistence(t, rulesSchema, MkRule).Schema
|
|
|
|
structure.AssertOptionalArguments(t, ruleSchema, []string{
|
|
mkSecurityGroup,
|
|
mkRuleAction,
|
|
mkRuleType,
|
|
mkRuleComment,
|
|
mkRuleDest,
|
|
mkRuleDPort,
|
|
mkRuleEnabled,
|
|
mkRuleIFace,
|
|
mkRuleLog,
|
|
mkRuleMacro,
|
|
mkRuleProto,
|
|
mkRuleSource,
|
|
mkRuleSPort,
|
|
})
|
|
|
|
structure.AssertValueTypes(t, ruleSchema, map[string]schema.ValueType{
|
|
mkRulePos: schema.TypeInt,
|
|
mkRuleAction: schema.TypeString,
|
|
mkRuleType: schema.TypeString,
|
|
mkRuleComment: schema.TypeString,
|
|
mkRuleDest: schema.TypeString,
|
|
mkRuleDPort: schema.TypeString,
|
|
mkRuleEnabled: schema.TypeBool,
|
|
mkRuleIFace: schema.TypeString,
|
|
mkRuleLog: schema.TypeString,
|
|
mkRuleMacro: schema.TypeString,
|
|
mkRuleProto: schema.TypeString,
|
|
mkRuleSource: schema.TypeString,
|
|
mkRuleSPort: schema.TypeString,
|
|
})
|
|
}
|