-
-
Notifications
You must be signed in to change notification settings - Fork 355
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
test: improve tests for NameFilter class. #3975
Changes from 6 commits
1947cfc
c68f244
5bd6499
3fbd091
ae2e352
f2d36c3
422365b
e039a75
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -111,13 +111,46 @@ public void setup() throws Exception { | |
|
||
@Test | ||
public void testNameFilter() throws Exception { | ||
// contract: legacy NameFilter is tested and works | ||
// contract: the constructor of the class NameFilter creates and initialises an object. | ||
|
||
CtClass<?> foo = factory.Package().get("spoon.test.filters.testclasses").getType("Foo"); | ||
assertEquals("Foo", foo.getSimpleName()); | ||
Rohitesh-Kumar-Jain marked this conversation as resolved.
Show resolved
Hide resolved
|
||
List<CtNamedElement> elements = foo.getElements(new NameFilter<>("i")); | ||
assertEquals(1, elements.size()); | ||
} | ||
|
||
@Test | ||
void testNameFilterMatchesReturnsTrueForMatchingName() { | ||
// contract: NameFilter.matches should return true for an element with a matching name | ||
|
||
// arrange | ||
String name = "someNiceName"; | ||
NameFilter<CtNamedElement> nameFilter = new NameFilter<>(name); | ||
CtNamedElement elemWithMatchingName = new Launcher().getFactory().createLocalVariable(); | ||
elemWithMatchingName.setSimpleName(name); | ||
|
||
// act | ||
boolean matches = nameFilter.matches(elemWithMatchingName); | ||
|
||
// assert | ||
assertTrue(matches); | ||
} | ||
Rohitesh-Kumar-Jain marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
@Test | ||
public void testNameFilterThrowsExceptionForNull() { | ||
// contract: NameFilter constructor should throw IllegalArgumentException when passed null | ||
|
||
assertThrows(IllegalArgumentException.class, () -> new NameFilter<>(null)); | ||
} | ||
|
||
@Test | ||
public void testNameFilterGetType() { | ||
// contract: getType method returns the datatype that the NameFilter class returns | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm truly sorry for going on and on here, but this contract still doesn't make sense to me. It says that a method returns the datatype that a class returns. But a class does not return anything, and so it does not make sense. It's very important to be able to succinctly specify what a test is supposed to verify, so we need to keep iterating on this until you've nailed it. Feel free to just comment in this comment with suggestions before committing to something. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
no no, it's my fault that iterations are still going on, had I raised a perfect PR, no iterations would have occurred. I will try to come with a succinct contract. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I would like to go with the one suggested by you only |
||
|
||
NameFilter<CtNamedElement> nameFilter = new NameFilter<>("i"); | ||
assertEquals(CtNamedElement.class, nameFilter.getType()); | ||
} | ||
|
||
@Test | ||
public void testFilters() { | ||
CtClass<?> foo = factory.Package().get("spoon.test.filters.testclasses").getType("Foo"); | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This contract is also not correct, this test is not for
NameFilter
's constructor. The test verifies thatNameFilter
finds the expected amount of elements when filtering with it (it's a very weak test).The original comment was technically correct, it was just pointless. But you don't have to change this contract when adding your other test methods, as you don't touch this test method. I'm guessing this is just left over from when you modified this method.
Either fix this comment such that it's correct, or revert to the original contract.