Skip to content
This repository has been archived by the owner on Jan 27, 2025. It is now read-only.

Commit

Permalink
Add random() Fix function. (#100)
Browse files Browse the repository at this point in the history
  • Loading branch information
blackwinter committed Jan 11, 2022
1 parent 0bc8c0b commit 5680007
Show file tree
Hide file tree
Showing 2 changed files with 40 additions and 1 deletion.
17 changes: 16 additions & 1 deletion metafix/src/main/java/org/metafacture/metafix/FixMethod.java
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.Random;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import java.util.stream.Collectors;
Expand Down Expand Up @@ -165,6 +166,14 @@ private boolean literalString(final String s) {
return s.startsWith("~");
}
},
random {
public void apply(final Metafix metafix, final Record record, final List<String> params, final Map<String, String> options) {
final String field = params.get(0);
final int max = getInteger(params, 1);

record.append(field, String.valueOf(RANDOM.nextInt(max)));
}
},
reject {
public void apply(final Metafix metafix, final Record record, final List<String> params, final Map<String, String> options) {
record.setReject(true);
Expand Down Expand Up @@ -258,7 +267,7 @@ public void apply(final Metafix metafix, final Record record, final List<String>
},
substring {
public void apply(final Metafix metafix, final Record record, final List<String> params, final Map<String, String> options) {
record.transformFields(params, s -> s.substring(Integer.parseInt(params.get(1)), Integer.parseInt(params.get(2)) - 1));
record.transformFields(params, s -> s.substring(getInteger(params, 1), getInteger(params, 2) - 1));
}
},
trim {
Expand All @@ -280,6 +289,12 @@ public void apply(final Metafix metafix, final Record record, final List<String>
private static final String FILEMAP_SEPARATOR_OPTION = "sep_char";
private static final String FILEMAP_DEFAULT_SEPARATOR = ",";

private static final Random RANDOM = new Random();

private static int getInteger(final List<String> params, final int index) {
return Integer.parseInt(params.get(index));
}

abstract void apply(Metafix metafix, Record record, List<String> params, Map<String, String> options);

}
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.junit.jupiter.api.extension.RegisterExtension;
import org.mockito.ArgumentMatchers;
import org.mockito.Mock;
import org.mockito.junit.MockitoJUnit;
import org.mockito.junit.MockitoRule;
Expand Down Expand Up @@ -1743,4 +1744,27 @@ public void accessArrayOfObjectsByDoListBind() {
});
}

@Test
public void shouldAddRandomNumber() {
MetafixTestHelpers.assertFix(streamReceiver, Arrays.asList(
"random(test, '100')"
),
i -> {
i.startRecord("1");
i.literal("title", "marc");
i.literal("title", "json");
i.endRecord();
},
o -> {
o.get().startRecord("1");
o.get().startEntity("title");
o.get().literal("1", "marc");
o.get().literal("2", "json");
o.get().endEntity();
o.get().literal(ArgumentMatchers.eq("test"), ArgumentMatchers.argThat(i -> Integer.parseInt(i) < 100));
o.get().endRecord();
}
);
}

}

0 comments on commit 5680007

Please sign in to comment.