Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[GITHUB-2897] Not exception but warning if some (not all) of the give… #2900

Merged
merged 33 commits into from
May 6, 2023
Merged
Show file tree
Hide file tree
Changes from 12 commits
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
86b4fb9
[GITHUB-2897] Not exception but warning if some (not all) of the give…
wenijinew Apr 25, 2023
06afe63
[GITHUB-2897] Not exception but warning if some (not all) of the give…
wenijinew Apr 25, 2023
1de108e
[GITHUB-2897] Not exception but warning if some (not all) of the give…
wenijinew Apr 25, 2023
ca68ec6
[GITHUB-2897] Not exception but warning if some (not all) of the give…
wenijinew Apr 25, 2023
0894435
[GITHUB-2897] Not exception but warning if some (not all) of the given
wenijinew Apr 26, 2023
62b3228
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 26, 2023
02d1c65
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 26, 2023
54f1650
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 26, 2023
e99c3bf
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 26, 2023
5a55f40
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 26, 2023
6e37114
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 26, 2023
e6fe1f0
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 26, 2023
1606e37
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 26, 2023
82278a5
Merge branch '2897' of https://github.com/wenijinew/testng into 2897
wenijinew Apr 27, 2023
60fe4f1
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 27, 2023
2ac193d
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 27, 2023
19f2761
A
wenijinew Apr 27, 2023
050ef65
Merge branch '2897' of https://github.com/wenijinew/testng into 2897
wenijinew Apr 27, 2023
6e02b46
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 27, 2023
99d1c9c
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 27, 2023
5bcd93e
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 27, 2023
31c7f8c
Merge branch '2897' of https://github.com/wenijinew/testng into 2897
wenijinew Apr 27, 2023
40d0396
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 27, 2023
7cba763
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 27, 2023
3beebda
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 27, 2023
d20f21a
Merge branch 'master' into 2897
wenijinew Apr 28, 2023
80fd124
Backward compatible when empty or blank test names are given
wenijinew Apr 29, 2023
2a12d6d
The option ignoredMissedTestNames should be passed from TestNG or con…
wenijinew Apr 29, 2023
153a46e
Optimize test cases, Fix legacy code smell, Make the meaning of ignor…
wenijinew Apr 29, 2023
210b10c
[GITHUB-2897] Not exception but warning if some
wenijinew Apr 29, 2023
1b421f3
Remove VM argument support
wenijinew May 5, 2023
4b0e483
Merge branch 'master' of https://github.com/wenijinew/testng into 2897
wenijinew May 5, 2023
3a1dc5e
[GITHUB-2897] Not exception but warning if some
wenijinew May 5, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 9 additions & 8 deletions CHANGES.txt
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
Current
New: GITHUB-2897: Not exception but warning if some (not all) of the given test names are not found in suite files. (Bruce Wen)
wenijinew marked this conversation as resolved.
Show resolved Hide resolved
Fixed: GITHUB-2888: Skipped Tests with DataProvider appear as failed (Joaquin Moreira)
Fixed: GITHUB-2884: Discrepancies with DataProvider and Retry of failed tests (Krishnan Mahadevan)
Fixed: GITHUB-2879: Test listeners specified in parent testng.xml file are not included in testng-failed.xml file (Krishnan Mahadevan)
Expand Down Expand Up @@ -1294,7 +1295,7 @@ Fixed: Wasn't parsing <selector-class-name> correctly
Fixed: Annotation Transformers now work on class-level annotations
Fixed: Some class-level @Test attributes were not always honored
Added: Clean separation between @Test invocation events and @Configuration invocation events
(see also TESTNG-111)
(see also TESTNG-111)
Added: Test instances created by @Factory now run in multiple threads in parallel mode
Fixed: @Before/@AfterGroups invocation order
Fixed: TESTNG-27: Parameters are not used on <test> level anymore
Expand Down Expand Up @@ -1462,8 +1463,8 @@ Fixed: TestNGAntTask was hardcoding m_haltOnFSP to true
Fixed: Passing a null parameter caused an NPE in the reports
Added: "listener" to the ant task (and documentation)
Added: if patch-testng-sourcedir.properties is found in the classpath
with a property "sourcedir" containing a ; separated list of
directories, this list will override -sourcedir.
with a property "sourcedir" containing a ; separated list of
directories, this list will override -sourcedir.

===========================================================================

Expand All @@ -1473,14 +1474,14 @@ Added: if patch-testng-sourcedir.properties is found in the classpath
Added: Maven 2 plug-in
Fixed: Message formattings in TestNG assertion utility class
Fixed: @Factory methods were counted as @Test as well
https://jira.opensymphony.com/browse/TESTNG-51
https://jira.opensymphony.com/browse/TESTNG-51
Fixed: All DataProvider parameters were shown in the HTML report
Fixed: Bug in testng-failed.xml generation
Fixed: <packages> bug when using a jar file to load the test classes
Added: alwaysRun for before @Configuration methods
https://jira.opensymphony.com/browse/TESTNG-35
https://jira.opensymphony.com/browse/TESTNG-35
Fixed: groupless @Configurations were not invoked if a method depends on a group
https://jira.opensymphony.com/browse/TESTNG-45
https://jira.opensymphony.com/browse/TESTNG-45
Added: beforeGroups/afterGroups to @Configuration

Eclipse plugin:
Expand Down Expand Up @@ -1621,7 +1622,7 @@ Fixed: Bug in <package> when directories contain spaces in their names
Fixed: Introduced a JDK5 dependency in the JDK1.4 build (getEnclosingClass())
Fixed: Output directory in ant task was not honored if it didn't exist
Fixed: Problem with timeout according to
https://forums.opensymphony.com/thread.jspa?threadID=6707
https://forums.opensymphony.com/thread.jspa?threadID=6707

Eclipse plug-in:

Expand All @@ -1631,7 +1632,7 @@ Added: Quick Fix for JUnit conversion (Annotations and JavaDoc)
Fixed: Methods Run as TestNG test
Added: Package level Run as TestNG test
Fixed: Resources from the linked directories are using a wrong path when
passed to command line TestNG
passed to command line TestNG

IDEA plug-in:

Expand Down
6 changes: 6 additions & 0 deletions testng-ant/src/main/java/org/testng/TestNGAntTask.java
Original file line number Diff line number Diff line change
Expand Up @@ -161,6 +161,7 @@ public class TestNGAntTask extends Task {
private String m_methods;
private Mode mode = Mode.testng;
private boolean forkJvm = true;
private boolean m_ignoreMissedTestNames;

public enum Mode {
// lower-case to better look in build scripts
Expand Down Expand Up @@ -360,6 +361,10 @@ public void setTestNames(String testNames) {
m_testNames = testNames;
}

public void setIgnoreMissedTestNames(boolean ignoreMissedTestNames) {
m_ignoreMissedTestNames = ignoreMissedTestNames;
}

/**
* Sets the suite runner class to invoke
*
Expand Down Expand Up @@ -578,6 +583,7 @@ protected List<String> createArguments() {
addStringIfNotBlank(argv, CommandLineArgs.SUITE_NAME, m_suiteName);
addStringIfNotBlank(argv, CommandLineArgs.TEST_NAME, m_testName);
addStringIfNotBlank(argv, CommandLineArgs.TEST_NAMES, m_testNames);
addBooleanIfTrue(argv, CommandLineArgs.IGNORE_MISSED_TEST_NAMES, m_ignoreMissedTestNames);
addStringIfNotBlank(argv, CommandLineArgs.METHODS, m_methods);
addReporterConfigs(argv);
addIntegerIfNotNull(argv, CommandLineArgs.SUITE_THREAD_POOL_SIZE, m_suiteThreadPoolSize);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ public final class RuntimeBehavior {

public static final String TESTNG_THREAD_AFFINITY = "testng.thread.affinity";
public static final String TESTNG_MODE_DRYRUN = "testng.mode.dryrun";
public static final String TESTNG_IGNORE_MISSED_TESTNAMES = "testng.ignore.missed.testnames";
private static final String TEST_CLASSPATH = "testng.test.classpath";
private static final String SKIP_CALLER_CLS_LOADER = "skip.caller.clsLoader";
public static final String TESTNG_USE_UNSECURED_URL = "testng.dtd.http";
Expand Down Expand Up @@ -115,6 +116,11 @@ public static boolean isDryRun() {
return Boolean.parseBoolean(value);
}

public static boolean ignoreMissedTestNames() {
wenijinew marked this conversation as resolved.
Show resolved Hide resolved
String value = System.getProperty(TESTNG_IGNORE_MISSED_TESTNAMES, "false");
return Boolean.parseBoolean(value);
}

/**
* @return - returns the {@link TimeZone} corresponding to the JVM argument <code>
* -Dtestng.timezone</code> if it was set. If not set, it returns the default timezone
Expand Down
8 changes: 8 additions & 0 deletions testng-core/src/main/java/org/testng/CommandLineArgs.java
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,14 @@ public class CommandLineArgs {
@Parameter(names = TEST_NAMES, description = "The list of test names to run")
public String testNames;

public static final String IGNORE_MISSED_TEST_NAMES = "-ignoreMissedTestNames";

@Parameter(
names = IGNORE_MISSED_TEST_NAMES,
description =
"Ignore missed test names given by '-testnames' and continue to run existing tests, if any.")
public boolean ignoreMissedTestNames = false;

public static final String TEST_JAR = "-testjar";

@Parameter(names = TEST_JAR, description = "A jar file containing the tests")
Expand Down
24 changes: 20 additions & 4 deletions testng-core/src/main/java/org/testng/JarFileUtils.java
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
class JarFileUtils {
private final IPostProcessor processor;
private final String xmlPathInJar;
private final boolean ignoreMissedTestNames;
private final List<String> testNames;
private final List<XmlSuite> suites = Lists.newLinkedList();
private final XmlSuite.ParallelMode mode;
Expand All @@ -36,10 +37,20 @@ class JarFileUtils {
String xmlPathInJar,
List<String> testNames,
XmlSuite.ParallelMode mode) {
this(processor, xmlPathInJar, testNames, mode, false);
}

JarFileUtils(
IPostProcessor processor,
String xmlPathInJar,
List<String> testNames,
XmlSuite.ParallelMode mode,
final boolean ignoreMissedTestNames) {
this.processor = processor;
this.xmlPathInJar = xmlPathInJar;
this.testNames = testNames;
this.mode = mode == null ? XmlSuite.ParallelMode.NONE : mode;
this.ignoreMissedTestNames = ignoreMissedTestNames;
}

List<XmlSuite> extractSuitesFrom(File jarFile) {
Expand Down Expand Up @@ -93,15 +104,20 @@ private boolean testngXmlExistsInJar(File jarFile, List<String> classes) throws
Collection<XmlSuite> parsedSuites = Parser.parse(suitePath, processor);
delete(file);
for (XmlSuite suite : parsedSuites) {
// If test names were specified, only run these test names
// If test names were specified, only run these test names. If any test names missed, then
// won't run any test names. (default legacy logic)
if (testNames != null) {
TestNamesMatcher testNamesMatcher = new TestNamesMatcher(suite, testNames);
testNamesMatcher.validateMissMatchedTestNames();
suites.addAll(testNamesMatcher.getSuitesMatchingTestNames());
boolean validationResult =
testNamesMatcher.validateMissMatchedTestNames(ignoreMissedTestNames);
if (validationResult) {
suites.addAll(testNamesMatcher.getSuitesMatchingTestNames());
}
wenijinew marked this conversation as resolved.
Show resolved Hide resolved
return validationResult;
} else {
suites.add(suite);
return true;
}
return true;
}
}
return false;
Expand Down
12 changes: 11 additions & 1 deletion testng-core/src/main/java/org/testng/TestNG.java
Original file line number Diff line number Diff line change
Expand Up @@ -354,7 +354,7 @@ private Collection<XmlSuite> processCommandLineArgs(Collection<XmlSuite> allSuit
}
// If test names were specified, only run these test names
TestNamesMatcher testNamesMatcher = new TestNamesMatcher(s, m_testNames);
testNamesMatcher.validateMissMatchedTestNames();
testNamesMatcher.validateMissMatchedTestNames(m_ignoreMissedTestNames);
result.addAll(testNamesMatcher.getSuitesMatchingTestNames());
}

Expand Down Expand Up @@ -799,6 +799,8 @@ public List<ISuiteListener> getSuiteListeners() {
/** The list of test names to run from the given suite */
private List<String> m_testNames;

private boolean m_ignoreMissedTestNames;

private Integer m_suiteThreadPoolSize = CommandLineArgs.SUITE_THREAD_POOL_SIZE_DEFAULT;

private boolean m_randomizeSuites = Boolean.FALSE;
Expand Down Expand Up @@ -1475,6 +1477,7 @@ protected void configure(CommandLineArgs cla) {

if (cla.testNames != null) {
setTestNames(Arrays.asList(cla.testNames.split(",")));
setIgnoreMissedTestNames(cla.ignoreMissedTestNames);
}

// Note: can't use a Boolean field here because we are allowing a boolean
Expand Down Expand Up @@ -1574,6 +1577,10 @@ protected void configure(CommandLineArgs cla) {
alwaysRunListeners(cla.alwaysRunListeners);
}

private void setIgnoreMissedTestNames(boolean ignoreMissedTestNames) {
m_ignoreMissedTestNames = ignoreMissedTestNames;
}

public void setSuiteThreadPoolSize(Integer suiteThreadPoolSize) {
m_suiteThreadPoolSize = suiteThreadPoolSize;
}
Expand Down Expand Up @@ -1641,6 +1648,9 @@ public void configure(Map cmdLineArgs) {
String testNames = (String) cmdLineArgs.get(CommandLineArgs.TEST_NAMES);
if (testNames != null) {
result.testNames = testNames;
result.ignoreMissedTestNames =
(Boolean)
cmdLineArgs.getOrDefault(CommandLineArgs.IGNORE_MISSED_TEST_NAMES, Boolean.FALSE);
}

String useDefaultListeners = (String) cmdLineArgs.get(CommandLineArgs.USE_DEFAULT_LISTENERS);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,19 @@
import java.util.List;
import org.testng.TestNGException;
import org.testng.collections.Lists;
import org.testng.internal.RuntimeBehavior;
import org.testng.log4testng.Logger;
import org.testng.xml.XmlSuite;
import org.testng.xml.XmlTest;

/** The class to work with "-testnames" */
/**
* The class to work with "-testnames", "-ignoreMissedTestNames", and VM argument
* "-Dtestng.ignore.missed.testnames"
*/
public final class TestNamesMatcher {

private static final Logger LOGGER = Logger.getLogger(TestNamesMatcher.class);

private final List<XmlSuite> cloneSuites = Lists.newArrayList();
private final List<String> matchedTestNames = Lists.newArrayList();
private final List<XmlTest> matchedTests = Lists.newArrayList();
Expand Down Expand Up @@ -43,13 +50,42 @@ public List<XmlSuite> getSuitesMatchingTestNames() {
return cloneSuites;
}

public void validateMissMatchedTestNames() {
List<String> tmpTestNames = Lists.newArrayList();
tmpTestNames.addAll(testNames);
tmpTestNames.removeIf(matchedTestNames::contains);
if (!tmpTestNames.isEmpty()) {
throw new TestNGException("The test(s) <" + tmpTestNames + "> cannot be found in suite.");
/**
* Do validation for testNames and notify users if any testNames are missed in suite. This method
* is also used to decide how to run test suite when test names are given. In legacy logic, if
* test names are given and exist in suite, then run them; if any of them do not exist in suite,
* then throw exception and exit. After ignoreMissedTestNames is introduced, if
* ignoreMissedTestNames is enabled, then any of the given test names exist in suite will be run,
* and print warning message to tell those test names do not exist in suite.
*
* @param ignoreMissedTestNames if true print warning message otherwise throw TestNGException for
* missed testNames.
* @return boolean if ignoreMissedTestNames disabled, then return true if no missed test names in
* suite, otherwise throw TestNGException; if ignoreMissedTestNames enabled, then return true
* if any test names exist in suite, otehrwise (all given test names are missed) false.
*/
public boolean validateMissMatchedTestNames(final boolean ignoreMissedTestNames) {
wenijinew marked this conversation as resolved.
Show resolved Hide resolved
final List<String> missedTestNames = getMissedTestNames();
if (!missedTestNames.isEmpty()) {
final String errMsg = "The test(s) <" + missedTestNames + "> cannot be found in suite.";

if (ignoreMissedTestNames || RuntimeBehavior.ignoreMissedTestNames()) {
wenijinew marked this conversation as resolved.
Show resolved Hide resolved
LOGGER.warn(errMsg);
// as long as any test names match, then tell caller to run them.
return !matchedTestNames.isEmpty();
} else {
// legacy, throw exception and exit execution
throw new TestNGException(errMsg);
}
}
return missedTestNames.isEmpty();
}

public List<String> getMissedTestNames() {
List<String> missedTestNames = Lists.newArrayList();
missedTestNames.addAll(testNames);
missedTestNames.removeIf(matchedTestNames::contains);
return missedTestNames;
}

public List<XmlTest> getMatchedTests() {
Expand Down
21 changes: 20 additions & 1 deletion testng-core/src/test/java/org/testng/JarFileUtilsTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
import java.util.List;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test;
import org.testng.internal.RuntimeBehavior;
import org.testng.testhelper.JarCreator;
import org.testng.xml.IPostProcessor;
import org.testng.xml.XmlClass;
Expand Down Expand Up @@ -65,6 +66,22 @@ public void testWithInvalidTestNames() throws MalformedURLException {
new String[] {"org.testng.jarfileutils.org.testng.SampleTest1"});
}

@Test(
description =
"GITHUB-2897, No TestNGException thrown when ignoreMissedTestNames enabled by System property 'testng.ignore.missed.testnames'.")
public void testWithInvalidTestNamesNoExceptionIfIgnoreMissedTestNamesEnabledBySystemProperty()
throws MalformedURLException {
String oldIgnoreMissedTestNames =
System.getProperty(RuntimeBehavior.TESTNG_IGNORE_MISSED_TESTNAMES, "false");
try {
System.setProperty(RuntimeBehavior.TESTNG_IGNORE_MISSED_TESTNAMES, "true");
JarFileUtils utils = newJarFileUtils(Collections.singletonList("testng-tests-child11"));
runTest(utils, 1, null, null, "Jar suite");
} finally {
System.setProperty(RuntimeBehavior.TESTNG_IGNORE_MISSED_TESTNAMES, oldIgnoreMissedTestNames);
}
}

@Test
public void testWithInvalidXmlFile() throws MalformedURLException {
JarFileUtils utils =
Expand Down Expand Up @@ -161,7 +178,9 @@ private static void runTest(
if (expectedTestNames != null) {
assertThat(testNames).containsExactly(expectedTestNames);
}
assertThat(classNames).contains(expectedClassNames);
if (expectedClassNames != null) {
assertThat(classNames).contains(expectedClassNames);
}
}

public static class FakeProcessor implements IPostProcessor {
Expand Down
Loading