All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.gematik.test.tiger.lib.rbel.RbelMessageNodeElementMatchExecutor Maven / Gradle / Ivy

/*
 * Copyright 2024 gematik GmbH
 *
 * 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
 *
 *     http://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 de.gematik.test.tiger.lib.rbel;

import static de.gematik.test.tiger.lib.rbel.RbelMessageValidator.getValueOrContentString;
import static org.assertj.core.api.Assertions.assertThat;

import de.gematik.rbellogger.data.RbelElement;
import java.util.List;
import java.util.regex.Pattern;
import java.util.regex.PatternSyntaxException;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.jetbrains.annotations.Nullable;

/**
 * Executor that takes a list of elements and performs matching / isEqual checks. If any elements
 * match for shouldMatch == TRUE or if none match for shouldMatch == FALSE this executor succeeds.
 * Else it will throw an AssertionError.
 */
@RequiredArgsConstructor
@AllArgsConstructor
@Builder
@Slf4j
public class RbelMessageNodeElementMatchExecutor {

  private final String rbelPath;
  private final String oracle;
  private final boolean shouldMatch;
  private final List elements;

  @Nullable private Pattern regexPattern;
  private boolean foundMatchingNode;

  public void execute() {
    assertThat(oracle)
        .withFailMessage("Matching string must not be empty for rbel path {}", rbelPath)
        .isNotBlank();

    compileRegexPattern();
    for (RbelElement element : elements) {
      if (foundMatchingNode) break;
      doesThisElementMatch(element);
    }
    if (shouldMatch && !foundMatchingNode) {
      if (elements.size() == 1) {
        throw new AssertionError(
            "Element value:\n" + elements.get(0).getRawStringContent() + "\nExpected:\n" + oracle);
      } else {
        throw new AssertionError(
            String.format(
                "Expected that nodes to rbel path '%s' are equal to or match '%s'",
                rbelPath, oracle));
      }
    }
  }

  private void compileRegexPattern() {
    try {
      regexPattern = Pattern.compile(oracle, Pattern.MULTILINE | Pattern.DOTALL);
    } catch (PatternSyntaxException pse) {
      log.atTrace()
          .addArgument(oracle)
          .addArgument(pse::getMessage)
          .log("Ignoring oracle '{}' as regex-pattern, error while compiling: '{}'");
      // nothing to do as we ignore invalid patterns (could be meant for isEqual checks)
    }
  }

  private void doesThisElementMatch(RbelElement element) {
    String text = getValueOrContentString(element);
    boolean itMatches =
        text.equals(oracle) || (regexPattern != null && regexPattern.matcher(text).matches());
    if (shouldMatch) {
      if (itMatches) {
        foundMatchingNode = true;
      }
    } else {
      if (itMatches) {
        throw new AssertionError(
            String.format(
                "Did not expect that value '%s' of node '%s' is equal to or matches '%s'",
                text, rbelPath, oracle));
      }
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy