mirror of
https://github.com/notherealmarco/coredns-deployment.git
synced 2025-05-05 12:32:34 +02:00
Alter existing "deprecated" function to return all migration notices (#159)
This commit is contained in:
parent
5960d7facb
commit
709b136563
7 changed files with 19 additions and 122 deletions
|
@ -13,7 +13,6 @@ Usage:
|
||||||
corefile-tool deprecated --from <coredns-ver> --to <coredns-ver> --corefile <path>
|
corefile-tool deprecated --from <coredns-ver> --to <coredns-ver> --corefile <path>
|
||||||
corefile-tool migrate --from <coredns-ver> --to <coredns-ver> --corefile <path> [--deprecations <true|false>]
|
corefile-tool migrate --from <coredns-ver> --to <coredns-ver> --corefile <path> [--deprecations <true|false>]
|
||||||
corefile-tool released --dockerImageId <id>
|
corefile-tool released --dockerImageId <id>
|
||||||
corefile-tool removed --from <coredns-ver> --to <coredns-ver> --corefile <path>
|
|
||||||
corefile-tool unsupported --from <coredns-ver> --to <coredns-ver> --corefile <path>
|
corefile-tool unsupported --from <coredns-ver> --to <coredns-ver> --corefile <path>
|
||||||
corefile-tool validversions
|
corefile-tool validversions
|
||||||
```
|
```
|
||||||
|
@ -25,14 +24,12 @@ The following operations are supported:
|
||||||
|
|
||||||
- `default`: returns true if the Corefile is the default for the given version of Kubernetes. If `--k8sversion` is not specified, then this will return true if the Corefile is the default for any version of Kubernetes supported by the tool.
|
- `default`: returns true if the Corefile is the default for the given version of Kubernetes. If `--k8sversion` is not specified, then this will return true if the Corefile is the default for any version of Kubernetes supported by the tool.
|
||||||
|
|
||||||
- `deprecated`: returns a list of plugins/options in the Corefile that have been deprecated.
|
- `deprecated`: returns a list of plugins/options in the Corefile that have been deprecated, removed, ignored or is a new default plugin/option.
|
||||||
|
|
||||||
- `migrate`: updates your CoreDNS corefile to be compatible with the `-to` version. Setting the `--deprecations` flag to `true` will migrate plugins/options as soon as they are announced as deprecated. Setting the `--deprecations` flag to `false` will migrate plugins/options only once they are removed (or made a no-op). The default is `false`.
|
- `migrate`: updates your CoreDNS corefile to be compatible with the `-to` version. Setting the `--deprecations` flag to `true` will migrate plugins/options as soon as they are announced as deprecated. Setting the `--deprecations` flag to `false` will migrate plugins/options only once they are removed (or made a no-op). The default is `false`.
|
||||||
|
|
||||||
- `released`: determines if the `--dockerImageID` was an official CoreDNS release or not. Only official releases of CoreDNS are supported by the tool.
|
- `released`: determines if the `--dockerImageID` was an official CoreDNS release or not. Only official releases of CoreDNS are supported by the tool.
|
||||||
|
|
||||||
- `removed`: returns a list plugins/options in the Corefile that have been removed from CoreDNS.
|
|
||||||
|
|
||||||
- `unsupported`: returns a list of plugins/options in the Corefile that are not supported by the migration tool (but may still be valid in CoreDNS).
|
- `unsupported`: returns a list of plugins/options in the Corefile that are not supported by the migration tool (but may still be valid in CoreDNS).
|
||||||
|
|
||||||
- `validversions`: Shows the list of CoreDNS versions supported by the this tool.
|
- `validversions`: Shows the list of CoreDNS versions supported by the this tool.
|
||||||
|
@ -57,11 +54,6 @@ corefile-tool deprecated --from 1.4.0 --to 1.5.0 --corefile /path/to/Corefile
|
||||||
corefile-tool unsupported --from 1.4.0 --to 1.5.0 --corefile /path/to/Corefile
|
corefile-tool unsupported --from 1.4.0 --to 1.5.0 --corefile /path/to/Corefile
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
|
||||||
# See removed plugins CoreDNS from v1.4.0 to v1.5.0.
|
|
||||||
corefile-tool removed --from 1.4.0 --to 1.5.0 --corefile /path/to/Corefile
|
|
||||||
```
|
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
# Migrate CoreDNS from v1.4.0 to v1.5.0 and also migrate all the deprecations
|
# Migrate CoreDNS from v1.4.0 to v1.5.0 and also migrate all the deprecations
|
||||||
# that are present in the current Corefile.
|
# that are present in the current Corefile.
|
||||||
|
|
|
@ -12,8 +12,8 @@ import (
|
||||||
func NewDeprecatedCmd() *cobra.Command {
|
func NewDeprecatedCmd() *cobra.Command {
|
||||||
deprecatedCmd := &cobra.Command{
|
deprecatedCmd := &cobra.Command{
|
||||||
Use: "deprecated",
|
Use: "deprecated",
|
||||||
Short: "Deprecated returns a list of deprecated plugins or directives present in the Corefile.",
|
Short: "Deprecated returns a list of deprecated, removed, ignored and new default plugins or directives present in the Corefile.",
|
||||||
Example: `# See deprecated plugins CoreDNS from v1.4.0 to v1.5.0.
|
Example: `# See deprecated, removed, ignored and new default plugins CoreDNS from v1.4.0 to v1.5.0.
|
||||||
corefile-tool deprecated --from 1.4.0 --to 1.5.0 --corefile /path/to/Corefile`,
|
corefile-tool deprecated --from 1.4.0 --to 1.5.0 --corefile /path/to/Corefile`,
|
||||||
RunE: func(cmd *cobra.Command, args []string) error {
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
from, _ := cmd.Flags().GetString("from")
|
from, _ := cmd.Flags().GetString("from")
|
||||||
|
|
|
@ -1,52 +0,0 @@
|
||||||
package cmd
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
|
|
||||||
"github.com/coredns/deployment/kubernetes/migration"
|
|
||||||
|
|
||||||
"github.com/spf13/cobra"
|
|
||||||
)
|
|
||||||
|
|
||||||
// NewRemovedCmd represents the removed command
|
|
||||||
func NewRemovedCmd() *cobra.Command {
|
|
||||||
removedCmd := &cobra.Command{
|
|
||||||
Use: "removed",
|
|
||||||
Short: "Removed returns a list of removed plugins or directives present in the Corefile.",
|
|
||||||
Example: `# See removed plugins CoreDNS from v1.4.0 to v1.5.0.
|
|
||||||
corefile-tool removed --from 1.4.0 --to 1.5.0 --corefile /path/to/Corefile`,
|
|
||||||
RunE: func(cmd *cobra.Command, args []string) error {
|
|
||||||
from, _ := cmd.Flags().GetString("from")
|
|
||||||
to, _ := cmd.Flags().GetString("to")
|
|
||||||
corefile, _ := cmd.Flags().GetString("corefile")
|
|
||||||
removed, err := removedCorefileFromPath(from, to, corefile)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("error while listing deprecated plugins: %v \n", err)
|
|
||||||
}
|
|
||||||
for _, rem := range removed {
|
|
||||||
fmt.Println(rem.ToString())
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
},
|
|
||||||
|
|
||||||
}
|
|
||||||
removedCmd.Flags().String("from", "", "Required: The version you are migrating from. ")
|
|
||||||
removedCmd.MarkFlagRequired("from")
|
|
||||||
removedCmd.Flags().String("to", "", "Required: The version you are migrating to.")
|
|
||||||
removedCmd.MarkFlagRequired("to")
|
|
||||||
removedCmd.Flags().String("corefile", "", "Required: The path where your Corefile is located.")
|
|
||||||
removedCmd.MarkFlagRequired("corefile")
|
|
||||||
|
|
||||||
return removedCmd
|
|
||||||
}
|
|
||||||
|
|
||||||
// removedCorefileFromPath takes the path where the Corefile is located and returns the plugins or directives
|
|
||||||
// that have been removed.
|
|
||||||
func removedCorefileFromPath(fromCoreDNSVersion, toCoreDNSVersion, corefilePath string) ([]migration.Notice, error) {
|
|
||||||
fileBytes, err := getCorefileFromPath(corefilePath)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
corefileStr := string(fileBytes)
|
|
||||||
return migration.Removed(fromCoreDNSVersion, toCoreDNSVersion, corefileStr)
|
|
||||||
}
|
|
|
@ -26,7 +26,6 @@ func CorefileTool() *cobra.Command {
|
||||||
|
|
||||||
`),
|
`),
|
||||||
}
|
}
|
||||||
rootCmd.AddCommand(NewRemovedCmd())
|
|
||||||
rootCmd.AddCommand(NewMigrateCmd())
|
rootCmd.AddCommand(NewMigrateCmd())
|
||||||
rootCmd.AddCommand(NewDefaultCmd())
|
rootCmd.AddCommand(NewDefaultCmd())
|
||||||
rootCmd.AddCommand(NewDeprecatedCmd())
|
rootCmd.AddCommand(NewDeprecatedCmd())
|
||||||
|
|
|
@ -12,18 +12,11 @@ import (
|
||||||
"github.com/coredns/deployment/kubernetes/migration/corefile"
|
"github.com/coredns/deployment/kubernetes/migration/corefile"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Deprecated returns a list of deprecated plugins or directives present in the Corefile. Each Notice returned is a
|
// Deprecated returns a list of deprecated, removed, ignored and new default plugins or directives present in the Corefile.
|
||||||
// warning, e.g. "plugin 'foo' is deprecated." An empty list returned means there are no deprecated plugins/options
|
// Each Notice returned is a warning, e.g. "plugin 'foo' is deprecated." An empty list returned means there are no
|
||||||
// present in the Corefile.
|
// deprecated, removed, ignored or new default plugins/options present in the Corefile.
|
||||||
func Deprecated(fromCoreDNSVersion, toCoreDNSVersion, corefileStr string) ([]Notice, error) {
|
func Deprecated(fromCoreDNSVersion, toCoreDNSVersion, corefileStr string) ([]Notice, error) {
|
||||||
return getStatus(fromCoreDNSVersion, toCoreDNSVersion, corefileStr, deprecated)
|
return getStatus(fromCoreDNSVersion, toCoreDNSVersion, corefileStr, all)
|
||||||
}
|
|
||||||
|
|
||||||
// Removed returns a list of removed plugins or directives present in the Corefile. Each Notice returned is a warning,
|
|
||||||
// e.g. "plugin 'foo' is no longer supported." An empty list returned means there are no removed plugins/options
|
|
||||||
// present in the Corefile.
|
|
||||||
func Removed(fromCoreDNSVersion, toCoreDNSVersion, corefileStr string) ([]Notice, error) {
|
|
||||||
return getStatus(fromCoreDNSVersion, toCoreDNSVersion, corefileStr, removed)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Unsupported returns a list of plugins that are not recognized/supported by the migration tool (but may still be valid in CoreDNS).
|
// Unsupported returns a list of plugins that are not recognized/supported by the migration tool (but may still be valid in CoreDNS).
|
||||||
|
@ -57,10 +50,10 @@ func getStatus(fromCoreDNSVersion, toCoreDNSVersion, corefileStr, status string)
|
||||||
if !present {
|
if !present {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
if vp.status == status {
|
if vp.status != "" {
|
||||||
notices = append(notices, Notice{
|
notices = append(notices, Notice{
|
||||||
Plugin: p.Name,
|
Plugin: p.Name,
|
||||||
Severity: status,
|
Severity: vp.status,
|
||||||
Version: v,
|
Version: v,
|
||||||
ReplacedBy: vp.replacedBy,
|
ReplacedBy: vp.replacedBy,
|
||||||
Additional: vp.additional,
|
Additional: vp.additional,
|
||||||
|
@ -86,8 +79,8 @@ func getStatus(fromCoreDNSVersion, toCoreDNSVersion, corefileStr, status string)
|
||||||
if !present {
|
if !present {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
if vo.status == status {
|
if vo.status != "" {
|
||||||
notices = append(notices, Notice{Plugin: p.Name, Option: o.Name, Severity: status, Version: v})
|
notices = append(notices, Notice{Plugin: p.Name, Option: o.Name, Severity: vo.status, Version: v})
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ func TestMigrate(t *testing.T) {
|
||||||
expectedCorefile string
|
expectedCorefile string
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
name: "Remove invalid proxy option",
|
name: "Remove invalid proxy option",
|
||||||
fromVersion: "1.1.3",
|
fromVersion: "1.1.3",
|
||||||
toVersion: "1.2.6",
|
toVersion: "1.2.6",
|
||||||
deprecations: true,
|
deprecations: true,
|
||||||
|
@ -56,7 +56,7 @@ func TestMigrate(t *testing.T) {
|
||||||
`,
|
`,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "Migrate from proxy to forward and handle Kubernetes deprecations",
|
name: "Migrate from proxy to forward and handle Kubernetes deprecations",
|
||||||
fromVersion: "1.3.1",
|
fromVersion: "1.3.1",
|
||||||
toVersion: "1.5.0",
|
toVersion: "1.5.0",
|
||||||
deprecations: true,
|
deprecations: true,
|
||||||
|
@ -96,7 +96,7 @@ func TestMigrate(t *testing.T) {
|
||||||
`,
|
`,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "add missing loop and ready plugins",
|
name: "add missing loop and ready plugins",
|
||||||
fromVersion: "1.1.3",
|
fromVersion: "1.1.3",
|
||||||
toVersion: "1.5.0",
|
toVersion: "1.5.0",
|
||||||
deprecations: true,
|
deprecations: true,
|
||||||
|
@ -132,7 +132,6 @@ func TestMigrate(t *testing.T) {
|
||||||
}
|
}
|
||||||
`,
|
`,
|
||||||
},
|
},
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, testCase := range testCases {
|
for _, testCase := range testCases {
|
||||||
|
@ -155,6 +154,7 @@ func TestDeprecated(t *testing.T) {
|
||||||
startCorefile := `.:53 {
|
startCorefile := `.:53 {
|
||||||
errors
|
errors
|
||||||
health
|
health
|
||||||
|
ready
|
||||||
kubernetes cluster.local in-addr.arpa ip6.arpa {
|
kubernetes cluster.local in-addr.arpa ip6.arpa {
|
||||||
pods insecure
|
pods insecure
|
||||||
upstream
|
upstream
|
||||||
|
@ -172,48 +172,12 @@ func TestDeprecated(t *testing.T) {
|
||||||
expected := []Notice{
|
expected := []Notice{
|
||||||
{Plugin: "kubernetes", Option: "upstream", Severity: deprecated, Version: "1.4.0"},
|
{Plugin: "kubernetes", Option: "upstream", Severity: deprecated, Version: "1.4.0"},
|
||||||
{Plugin: "proxy", Severity: deprecated, ReplacedBy: "forward", Version: "1.4.0"},
|
{Plugin: "proxy", Severity: deprecated, ReplacedBy: "forward", Version: "1.4.0"},
|
||||||
}
|
{Plugin: "ready", Severity: newdefault, Version: "1.5.0"},
|
||||||
|
{Option: "upstream", Plugin: "kubernetes", Severity: ignored, Version: "1.5.0"},
|
||||||
result, err := Deprecated("1.3.1", "1.5.0", startCorefile)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(result) != len(expected) {
|
|
||||||
t.Fatalf("expected to find %v deprecations; got %v", len(expected), len(result))
|
|
||||||
}
|
|
||||||
|
|
||||||
for i, dep := range expected {
|
|
||||||
if result[i].ToString() != dep.ToString() {
|
|
||||||
t.Errorf("expected to get '%v'; got '%v'", dep.ToString(), result[i].ToString())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestRemoved(t *testing.T) {
|
|
||||||
startCorefile := `.:53 {
|
|
||||||
errors
|
|
||||||
health
|
|
||||||
kubernetes cluster.local in-addr.arpa ip6.arpa {
|
|
||||||
pods insecure
|
|
||||||
upstream
|
|
||||||
fallthrough in-addr.arpa ip6.arpa
|
|
||||||
}
|
|
||||||
prometheus :9153
|
|
||||||
proxy . /etc/resolv.conf
|
|
||||||
cache 30
|
|
||||||
loop
|
|
||||||
reload
|
|
||||||
loadbalance
|
|
||||||
}
|
|
||||||
`
|
|
||||||
|
|
||||||
expected := []Notice{
|
|
||||||
{Plugin: "proxy", Severity: removed, ReplacedBy: "forward", Version: "1.5.0"},
|
{Plugin: "proxy", Severity: removed, ReplacedBy: "forward", Version: "1.5.0"},
|
||||||
}
|
}
|
||||||
|
|
||||||
result, err := Removed("1.3.1", "1.5.0", startCorefile)
|
result, err := Deprecated("1.3.1", "1.5.0", startCorefile)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
|
|
|
@ -41,4 +41,5 @@ const (
|
||||||
removed = "removed" // plugin/option has been removed from CoreDNS
|
removed = "removed" // plugin/option has been removed from CoreDNS
|
||||||
unsupported = "unsupported" // plugin/option is not supported by the migration tool
|
unsupported = "unsupported" // plugin/option is not supported by the migration tool
|
||||||
newdefault = "newdefault" // plugin/option was added to the default corefile
|
newdefault = "newdefault" // plugin/option was added to the default corefile
|
||||||
|
all = "all" // all plugin/option that are deprecated, ignored, removed and new defaults.
|
||||||
)
|
)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue