Comments (12)
I didn't have time this week, but I'll try to do it next week.
from testparameterinjector.
The class under test should have a default constructor, so you could check that.
If there is no obvious error there, we don't explicitly support Powermock. If you think there is a fix that we could do on our side to support Powermock, I'm happy to consider it.
from testparameterinjector.
Constructor present or absent in the class under test doesn't seem to make a difference. The powermock delegation seems to be creating an additional constructor.
I haven't yet looked at a possible solution, but wondering what is the purpose of this check for a single constructor?
from testparameterinjector.
One potential fix would be check for the public constructor and use that to get the annotations?
private ImmutableList<Optional<TestParametersValues>>
getConstructorParametersOrSingleAbsentElement(Class<?> testClass) {
Constructor<?> constructor = getOnlyConstructor(testClass);
return hasRelevantAnnotation(constructor)
? FluentIterable.from(getConstructorParameters(constructor))
.transform(Optional::of)
.toList()
: ImmutableList.of(Optional.absent());
}
from testparameterinjector.
Here's a fix that I tried locally and works, change is in getOnlyConstructor
. Thoughts? I can create a PR if needed.
if (constructors.size() > 1 && testClass.isAnnotationPresent(PowerMockRunnerDelegate.class)) {
for (Constructor<?> constructor : constructors) {
if (Modifier.isPublic(constructor.getModifiers())) {
return getOnlyElement(ImmutableList.of(constructor));
}
}
}
from testparameterinjector.
Upon further investigation, it looks like the issue happens only when PowerMockRunner
and EasyMockSupport
is used. For example, I was able to repro the issue with the following class in this repo.
@RunWith(PowerMockRunner.class)
@PowerMockRunnerDelegate(TestParameterInjector.class)
public class PowerMockDelegateTest extends EasyMockSupport {
public PowerMockDelegateTest() {
}
@Test
public void test(@TestParameter boolean parameter) {
assertThat(this.getClass().getAnnotation(PowerMockRunnerDelegate.class).annotationType())
.isEqualTo(PowerMockRunnerDelegate.class);
}
}
from testparameterinjector.
Looks the test runner itself is using getTestClass().getOnlyConstructor()
, which is probably modified by Powermock to do the right thing. But then later, the following custom method is called by TestParameterInjector:
private static Constructor<?> getOnlyConstructor(Class<?> testClass) {
ImmutableList<Constructor<?>> constructors =
ImmutableList.copyOf(testClass.getDeclaredConstructors());
checkState(
constructors.size() == 1, "Expected exactly one constructor, but got %s", constructors);
return getOnlyElement(constructors);
}
Ideally, we'd use getTestClass().getOnlyConstructor()
throughout the codebase, but that's a big refactor. Instead, I'm thinking of being more lenient and filtering out non-public constructors first and let getTestClass().getOnlyConstructor()
do the validation.
from testparameterinjector.
Could you check locally if this works?
import static com.google.common.collect.MoreCollectors.onlyElement;
constructors.stream().filter(c -> Modifier.isPublic(c.getModifiers())).collect(onlyElement())
from testparameterinjector.
yes, this works, @nymanjens
from testparameterinjector.
Are you planning to push your change? @nymanjens
from testparameterinjector.
I'll make a release (1.14) for this so you can test the updated code
from testparameterinjector.
great, thank you so much!
from testparameterinjector.
Related Issues (20)
- Build fails with firebase dependency HOT 3
- Support JUnit 5 HOT 27
- Support non-number floating point values HOT 2
- Support tests written in kotlin with parameter types that are `@JvmInline` value classes HOT 4
- Wrong transitive dependency protobuf HOT 3
- Feature request: shade protobuf dependency HOT 6
- Test naming changed from 1.8 to 1.9 for `float`s HOT 6
- JUnit 5: Support `@Nested` classes HOT 5
- Run in Firebase Test Lab HOT 2
- Feature request: Expose `PluggableTestRunner` HOT 2
- Trying to run the test but nothing happened
- How to be inject parameter into the test class constructor HOT 2
- How to set custom name for `@TestParameter` HOT 2
- Running a single test using maven verify HOT 2
- test execution time is not accurate HOT 10
- Non-static method support for dynamic parameter generation HOT 10
- Run a single test in IntelliJ HOT 12
- Consider keeping a changelog? HOT 1
- Can't use more than one `TestParameter` annotation with Android Instrumentation tests. HOT 8
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from testparameterinjector.