From aeb727bdd997dac0debe884931eb5af2bec487c5 Mon Sep 17 00:00:00 2001 From: Vadzim Hushchanskou Date: Fri, 1 Nov 2024 13:42:52 +0300 Subject: [PATCH] Fix possible NullPointerException --- .../templating/TemplateProcessing.java | 26 +++++++------------ 1 file changed, 10 insertions(+), 16 deletions(-) diff --git a/src/main/java/com/epam/reportportal/utils/formatting/templating/TemplateProcessing.java b/src/main/java/com/epam/reportportal/utils/formatting/templating/TemplateProcessing.java index a652e7f0..2a9af758 100644 --- a/src/main/java/com/epam/reportportal/utils/formatting/templating/TemplateProcessing.java +++ b/src/main/java/com/epam/reportportal/utils/formatting/templating/TemplateProcessing.java @@ -56,9 +56,8 @@ private TemplateProcessing() { * @param config templating mechanism configuration * @return formatted string */ - public static String processTemplate(@Nonnull String pattern, @Nullable Object object, - @Nullable Executable executable, @Nullable Map parameters, - @Nonnull TemplateConfiguration config) { + public static String processTemplate(@Nonnull String pattern, @Nullable Object object, @Nullable Executable executable, + @Nullable Map parameters, @Nonnull TemplateConfiguration config) { HashMap myParams = ofNullable(parameters).map(HashMap::new).orElseGet(HashMap::new); ofNullable(executable).ifPresent(e -> { myParams.put(config.getMethodName(), e.getName()); @@ -72,9 +71,7 @@ public static String processTemplate(@Nonnull String pattern, @Nullable Object o while (matcher.find()) { String templatePart = matcher.group(1); String replacement = getReplacement(templatePart, myParams, config); - matcher.appendReplacement(stringBuffer, - Matcher.quoteReplacement(replacement != null ? replacement : matcher.group(0)) - ); + matcher.appendReplacement(stringBuffer, Matcher.quoteReplacement(replacement != null ? replacement : matcher.group(0))); } matcher.appendTail(stringBuffer); return stringBuffer.toString(); @@ -131,14 +128,12 @@ private static String getReplacement(@Nonnull String templatePart, @Nonnull Map< * @return {@link String} representation of object field(s) value(s). * @throws NoSuchFieldException if field not found */ - public static String retrieveValue(TemplateConfiguration templateConfig, int index, String[] fields, Object object) - throws NoSuchFieldException { - - if (object == null) { - return NULL_VALUE; - } - + public static String retrieveValue(@Nonnull TemplateConfiguration templateConfig, int index, @Nonnull String[] fields, + @Nullable Object object) throws NoSuchFieldException { for (int i = index; i < fields.length; i++) { + if (object == null) { + return NULL_VALUE; + } if (object.getClass().isArray()) { return parseArray(templateConfig, (Object[]) object, i, fields); } @@ -150,7 +145,6 @@ public static String retrieveValue(TemplateConfiguration templateConfig, int ind object = Accessible.on(object).field(fields[i]).getValue(); } - return parseDescendant(templateConfig, object); } @@ -184,8 +178,8 @@ private static String parseArray(TemplateConfiguration templateConfig, Object[] * @param fields Fields of the template part * @return {@link String} representation of the parsed Collection */ - private static String parseCollection(TemplateConfiguration templateConfig, Iterable iterable, int index, - String[] fields) throws NoSuchFieldException { + private static String parseCollection(TemplateConfiguration templateConfig, Iterable iterable, int index, String[] fields) + throws NoSuchFieldException { StringBuilder stringBuilder = new StringBuilder(); stringBuilder.append(templateConfig.getIterableStart());