• Configuring Robolectric


    There are numerous ways to customize how Robolectric behaves at runtime.

    Config Annotation

    The primary way to customize Robolectric is done via the @Config annotation. The annotation can be applied to classes and methods, with the values specified at the method level overriding the values specified at the class level.

    //定制robolectric的主要方法是通过@Config注解,这个注解可以被使用在类上和方法上。方法上的value会重写类层的value

    Base classes are also searched for annotations, so if you find yourself specifying the same values on a large number of tests, you can create a base class and move your @Config annotation to that class.

    //基类也会被注解搜索,所以如果你发现你自己定义了很多同样的value在大量的测试类中,你可以创建一个基类。然后让@Config注解指向这个基类

    The following examples show how to handle common setup tasks:

    Configure SDK Level

    Robolectric will run your code against the targetSdkVersion specified in your manifest. If you want to test how specific pieces of code behave under a different SDK level, you can change the sdk version by setting:

    //robolectric运行代码是基于你声明的targetsdkversion版本。如果你想测试特定的代码片段在不懂sdk level的效果。你可以如下面方法修改sdk version:

    @Config(sdk = Build.VERSION_CODES.JELLY_BEAN)
    public class SandwichTest {
    
        @Config(sdk = Build.VERSION_CODES.KITKAT)
        public void getSandwich_shouldReturnHamSandwich() {
        }
    }
    

    Configure Application Class

    Robolectric will attempt to create an instance of your Application class as specified in the manifest. If you want to provide a custom implementation, you can specify it by setting:

    //robolectric尝试创建一个在manifest中指定的application实例。如果你想提供一个自定义的实现,使用下面的方法实现:

    @Config(application = CustomApplication.class)
    public class SandwichTest {
    
        @Config(application = CustomApplicationOverride.class)
        public void getSandwich_shouldReturnHamSandwich() {
        }
    }
    

    Configure Resource Paths

    Robolectric provides defaults for Gradle and Maven, but allows you to customize the path to your manifest, resource directory, and assets directory. This can be useful if you have a custom build system. You can specify these values by setting:

    //rebolectric支持自定义manifest,resource目录,assets目录等默认路径

    @Config(manifest = "some/build/path/AndroidManifest.xml")
    public class SandwichTest {
    
        @Config(manifest = "other/build/path/AndroidManifest.xml")
        public void getSandwich_shouldReturnHamSandwich() {
        }
    }
    

    By default, Robolectric will assume that your resources and assets are located in directories named res and assets, respectively. These paths are assumed to be relative to the directory where the manifest is located. You can change these values by adding theresourceDir and assetDir options to the @Config annotaton.

    //使用resourceDir and assetDir选项来配置目录

    Config Properties

    Any option that can be specified in a @Config annotation can also be specified globally in a properties file. Create a file namedrobolectric.properties and make sure it can be found on the classpath. Below is an example:

    //可以创建一个robolectric.properties文件来指定全局配置的变量,如下例子:

    sdk=18
    manifest=some/build/path/AndroidManifest.xml
    shadows=my.package.ShadowFoo,my.package.ShadowBar
    

    System Properties

    Some options can be configured globally by setting these system properties:

    • robolectric.offline - Set to true to disable runtime fetching of jars.
    • robolectric.dependency.dir - When in offline mode, specifies a folder containing runtime dependencies.
    • robolectric.dependency.repo.id - Set the ID of the Maven repository to use for the runtime dependencies (default sonatype).
    • robolectric.dependency.repo.url - Set the URL of the Maven repository to use for the runtime dependencies (defaulthttps://oss.sonatype.org/content/groups/public/).
    • robolectric.logging.enabled - Set to true to enable debug logging.

    When using Gradle, you can configure the System Properties for unit tests with the all block (see here). For example, to override the Maven repository URL and ID to download the runtime dependencies from a repository other than Sonatype:

    android {
      testOptions {
        unitTests.all {
          systemProperty 'robolectric.dependency.repo.url', 'https://local-mirror/repo'
          systemProperty 'robolectric.dependency.repo.id', 'local'
        }
      }
    }
    ----------- Do not start just casually, and do not end just casually. -----------
  • 相关阅读:
    Python 双向链表的实现
    Python 单链表实现
    分享两种 Python 中的单例模式
    HTML 盒子模型
    HTML 行高
    HTML 超链接 文本修饰 背景属性
    HTML 标签分类
    HTML 文字,样式表
    HTML CSS
    HTML 锚点 空链 超链优化写法
  • 原文地址:https://www.cnblogs.com/yexiant/p/5692096.html
Copyright © 2020-2023  润新知