
The KRM based k8s applier solves multiple design problems which were introduced in previous airshipctl generation, making apply code and process more clear, reliable and readable. In particular: * k8s applier now is a KRM function and it allows the end user to choose or implement desired backend for k8s apply operations; * the related amount of code was reduced by three times, multiple unused and unnecessary structs/interfaces/design patterns were removed or rewrited in more clean and efficient way; * removed cli-utils dependency from airshipctl; * fixed several bugs and code issues, such as incorrect printing of tables, duplicated unit tests, improper generation and applying inventory config map, etc; * cli-utils version used in KRM function was bumped to 0.26.0; * phases with duplicated k8s resources were removed or fixed; * unit test coverage increased to 83.1%; * KRM function logs were integrated with klog library which allows to observe logs directly from cli-utils and other dependent libs. Change-Id: Ief509f1d6abefd53caf7fcffc4e36b0319815373 Signed-off-by: Ruslan Aliev <raliev@mirantis.com> Closes: #646
70 lines
2.3 KiB
Go
Executable File
70 lines
2.3 KiB
Go
Executable File
/*
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
https://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package poller
|
|
|
|
import (
|
|
"context"
|
|
"strings"
|
|
|
|
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
|
|
"k8s.io/apimachinery/pkg/labels"
|
|
"k8s.io/klog/v2"
|
|
"sigs.k8s.io/cli-utils/pkg/kstatus/polling/clusterreader"
|
|
"sigs.k8s.io/controller-runtime/pkg/client"
|
|
)
|
|
|
|
const allowedApplyErrors = 3
|
|
|
|
// CachingClusterReader is wrapper for kstatus.CachingClusterReader implementation
|
|
type CachingClusterReader struct {
|
|
Cr *clusterreader.CachingClusterReader
|
|
applyErrors []error
|
|
}
|
|
|
|
// Get is a wrapper for kstatus.CachingClusterReader Get method
|
|
func (c *CachingClusterReader) Get(ctx context.Context, key client.ObjectKey, obj *unstructured.Unstructured) error {
|
|
return c.Cr.Get(ctx, key, obj)
|
|
}
|
|
|
|
// ListNamespaceScoped is a wrapper for kstatus.CachingClusterReader ListNamespaceScoped method
|
|
func (c *CachingClusterReader) ListNamespaceScoped(
|
|
ctx context.Context,
|
|
list *unstructured.UnstructuredList,
|
|
namespace string,
|
|
selector labels.Selector) error {
|
|
return c.Cr.ListNamespaceScoped(ctx, list, namespace, selector)
|
|
}
|
|
|
|
// ListClusterScoped is a wrapper for kstatus.CachingClusterReader ListClusterScoped method
|
|
func (c *CachingClusterReader) ListClusterScoped(
|
|
ctx context.Context,
|
|
list *unstructured.UnstructuredList,
|
|
selector labels.Selector) error {
|
|
return c.Cr.ListClusterScoped(ctx, list, selector)
|
|
}
|
|
|
|
// Sync is a wrapper for kstatus.CachingClusterReader Sync method, allows to filter specific errors
|
|
func (c *CachingClusterReader) Sync(ctx context.Context) error {
|
|
err := c.Cr.Sync(ctx)
|
|
if err != nil && strings.Contains(err.Error(), "request timed out") {
|
|
c.applyErrors = append(c.applyErrors, err)
|
|
if len(c.applyErrors) <= allowedApplyErrors {
|
|
klog.V(2).Infof("timeout error occurred during sync: '%v', skipping", err)
|
|
return nil
|
|
}
|
|
}
|
|
return err
|
|
}
|