ElectricSpock
What's new
The latest version is 0.9. Past history of the library is over there.
Version 0.8 tested with Robolectric 3.7.1 and Android Gradle Plugin 3.0.1. There is no real code change. Just update version check.
IMPORTANT: Starting from ElectricSpock 0.7, the library will no longer expose the dependent library implicitly. This means you have to add dependencies of Robolectric, Spock Framework and Groovy explicitly. This reduce the chances of version conflict in future. See Installation for details.
For those who stick to Robolectric 3.2, please use version 0.4.1.
For those who stick to Robolectric 3.1, please use version 0.1.
About
The Android test framework Robolectric is designed with JUnit in mind and it does not work well with Spock framework. Fortunately there is a project RoboSpock is designed for that. It configure Robolectric properly under the framework of Spock framework. However it based on some internal source code of Robolectric and it has no official support to Robolectric 3.1 yet. There is an issue for that, but it has been quite some time. So I decided to make my own.
It is heavily based on RoboSpock project. It borrow a lot of code from there, and make some tweak of my own. This project is never possible without the excellent foundation.
Current version (0.9) of the library is tested with Robolectric 3.8.
- test with Robolectric 3.7.1
Installation (Gradle)
The archive of this project is deployed with jitpack. Add the following to your gradle build script.
Add it in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
Add the dependencies
// AGP 3.0
dependencies {
testImplementation 'com.github.hkhc:electricspock:0.9'
testImplementation 'org.robolectric:robolectric:3.7.1'
testImplementation 'org.robolectric:shadows-support-v4:3.4-rc2'
testImplementation 'org.codehaus.groovy:groovy-all:2.4.12'
testImplementation 'org.spockframework:spock-core:1.1-groovy-2.4'
}
// pre-AGP 3.0
dependencies {
testCompile 'com.github.hkhc:electricspock:0.9'
testCompile 'org.robolectric:robolectric:3.7.1'
testCompile 'org.robolectric:shadows-support-v4:3.4-rc2'
testCompile 'org.codehaus.groovy:groovy-all:2.4.12'
testCompile 'org.spockframework:spock-core:1.1-groovy-2.4'
}
Then we may just write Spock specification with ElectricSpecification
class and Robolectric's @Config
annotation
@Config(constants=BuildConfig)
class MySpec extends ElectricSpecification {
def "Robolectric is enabled"() {
when: "invoking call to Android API"
android.util.Log.d("TAG", "Hello world")
then: "there should not be any error"
notThrown Exception
}
}
ElectricSuite
The class ElectricSuite
is a helper class to help organize test methods of Specification into group. It is essentially a test class with Suite
runner. However we don't need to use @SuiteClasses
annotation to specify test classes. Instead the class scan all static inner class as test classes.
For example
class MySpec extends ElectricSuite {
static class MyInnerSpec1 extends ElectricSpecification {
[....]
}
static class MyInnerSpec2 extends ElectricSpecification [
[....]
}
}
Please note that there are a few limitations:
-
We cannot have any test method in the
ElectricSuite
class. All test methods shall be in the inner test classes ofElectricSuite
. -
(ElecrtricSpock 0.5 fixed this)
When using with Spock-reporting-plugin, all inner classes of the sameElectricSuite
class shall have the same base class. i.e. Either all of them extend fromElectricSpecification
orSpecification
. Mix of different base classes will cause exception in the reporting plugin. It will be something likeOverlappingFileLockException
.