From 92fb7c3a703d798af018addf81bdff2c08ca75aa Mon Sep 17 00:00:00 2001 From: Xingjian Zhang <44231913+THUzxj@users.noreply.github.com> Date: Fri, 29 Mar 2024 03:28:58 +0800 Subject: [PATCH] Add details to error operator log (#375) * Add details to error operator log * Update test for new error log reporting --- acto/checker/impl/operator_log.py | 1 + acto/checker/impl/tests/test_operator_log.py | 3 +++ acto/common.py | 6 ++++-- 3 files changed, 8 insertions(+), 2 deletions(-) diff --git a/acto/checker/impl/operator_log.py b/acto/checker/impl/operator_log.py index cd005a057e..88e975b970 100644 --- a/acto/checker/impl/operator_log.py +++ b/acto/checker/impl/operator_log.py @@ -34,6 +34,7 @@ def check( ) if is_invalid: return InvalidInputResult( + message=value, responsible_property=invalid_field_path ) # We reported error if we found error in the operator log diff --git a/acto/checker/impl/tests/test_operator_log.py b/acto/checker/impl/tests/test_operator_log.py index 6144b2e374..324a9e9a71 100644 --- a/acto/checker/impl/tests/test_operator_log.py +++ b/acto/checker/impl/tests/test_operator_log.py @@ -24,13 +24,16 @@ def checker_func(s: Snapshot, prev_s: Snapshot) -> Optional[InvalidInputResult]: enumerate( [ InvalidInputResult( + message="StatefulSet.apps \"test-cluster-server\" is invalid: spec.template.spec.restartPolicy: Unsupported value: \"OnFailure\": supported values: \"Always\"", responsible_property=PropertyPath([]), ), None, InvalidInputResult( + message="tidb cluster acto-namespace/test-cluster is not valid and must be fixed first, aggregated error: spec.tidb.volumeName: Invalid value: \"lsgqejeydt\": Can not find volumeName: lsgqejeydt in storageVolumes or additionalVolumes/additionalVolumeMounts", responsible_property=PropertyPath([]), ), InvalidInputResult( + message="github.com/rabbitmq/cluster-operator/controllers.(*RabbitmqClusterReconciler).Reconcile\n\t/workspace/controllers/rabbitmqcluster_controller.go:260\nsigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).reconcileHandler\n\t/go/pkg/mod/sigs.k8s.io/controller-runtime@v0.9.6/pkg/internal/controller/controller.go:298\nsigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).processNextWorkItem\n\t/go/pkg/mod/sigs.k8s.io/controller-runtime@v0.9.6/pkg/internal/controller/controller.go:253\nsigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).Start.func2.2\n\t/go/pkg/mod/sigs.k8s.io/controller-runtime@v0.9.6/pkg/internal/controller/controller.go:214", responsible_property=PropertyPath( [ "spec", diff --git a/acto/common.py b/acto/common.py index bc0741d115..74eba6cc9e 100644 --- a/acto/common.py +++ b/acto/common.py @@ -583,11 +583,13 @@ def invalid_input_message( - when log indicates invalid input: the responsible field path for the invalid input """ logger = get_thread_logger(with_prefix=True) + is_invalid = False for regex in INVALID_INPUT_LOG_REGEX: if re.search(regex, log_msg): logger.info("Recognized invalid input through regex: %s", log_msg) - return True, PropertyPath([]) + is_invalid = True + break # Check if the log line contains the field or value # If so, also return True @@ -621,7 +623,7 @@ def invalid_input_message( ) return True, delta.path - return False, PropertyPath([]) + return is_invalid, PropertyPath([]) def canonicalize(s: str):