-
-
Notifications
You must be signed in to change notification settings - Fork 354
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 5 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() | ||
Rohitesh-Kumar-Jain marked this conversation as resolved.
Show resolved
Hide resolved
|
||
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 object of class NameFilter | ||
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. This contract is not correct, the 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. should the contract be like this : getType method returns the type of class which is begin used ? 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. There's no one answer to what a contract should say, but it cannot be incorrect. What the The contract comment should state in human-readable terms what the test is supposed to verify. One potential contract here would be: A less specific one would be: Note that we don't usually test getters directly, because they are trivial pieces of code, and so the test and its contract here necessarily become a bit contrived. 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 have one question, so I can skip adding tests for getter like 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.
Directly testing that would be fairly far down the priority list, yes. Note however that this isn't a pure getter in the sense that it doesn't just return a static value or a field of the class, but actually calls some other method. In that sense, it's not pointless to test it, but it would for example be much more important to thoroughly test |
||
|
||
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.