GithubHelp home page GithubHelp logo

cenkce / android-testing Goto Github PK

View Code? Open in Web Editor NEW

This project forked from bitrise-io/android-testing

0.0 1.0 0.0 10.92 MB

A collection of samples demonstrating different frameworks and techniques for automated testing

License: Apache License 2.0

Python 6.63% Java 76.26% Shell 0.30% HTML 1.83% Kotlin 14.97%

android-testing's Introduction

Android testing samples

A collection of samples demonstrating different frameworks and techniques for automated testing.

Espresso Samples

BasicSample - Basic Espresso sample

CustomMatcherSample - Shows how to extend Espresso to match the hint property of an EditText

DataAdapterSample - Showcases the onData() entry point for Espresso, for lists and AdapterViews

IdlingResourceSample - Synchronization with background jobs

IntentsBasicSample - Basic usage of intended() and intending()

IntentsAdvancedSample - Simulates a user fetching a bitmap using the camera

MultiWindowSample - Shows how to point Espresso to different windows

RecyclerViewSample - RecyclerView actions for Espresso

WebBasicSample - Use Espresso-web to interact with WebViews

BasicSampleBundled - Basic sample for Eclipse and other IDEs

MultiProcessSample - Showcases how to use multiprocess Espresso.

UiAutomator Sample

BasicSample - Basic UI Automator sample

AndroidJUnitRunner Sample

AndroidJunitRunnerSample - Showcases test annotations, parameterized tests and testsuite creation

JUnit4 Rules Sample

**All previous samples use ActivityTestRule or IntentsTestRule but there's one specific to ServiceTestRule:

BasicSample - Simple usage of ActivityTestRule

BasicSample-kotlinApp - Simple usage of ActivityTestRule with Kotlin

BasicSample-kotlinAppDetektGradle4.9 - Simple usage of ActivityTestRule with Kotlin, Detekt and Gradle 4.9

IntentsBasicSample - Simple usage of IntentsTestRule

ServiceTestRuleSample - Simple usage of ServiceTestRule

Prerequisites

  • Android SDK v23
  • Android Build Tools v23
  • Android Support Repository rev17

Getting Started

These samples use the Gradle build system. To build a project, enter the project directory and use the ./gradlew assemble command or use "Import Project" in Android Studio.

  • Use ./gradlew connectedAndroidTest to run the tests on a connected emulator or device.
  • Use ./gradlew test to run the unit test on your local host.

There is a top-level build.gradle file if you want to build and test all samples from the root directory. This is mostly helpful to build on a CI (Continuous Integration) server.

Android Testing Support Library

Many of these samples use the ATSL. Visit the Android Testing Support Library site for more information.

Experimental Bazel Support

Some of these samples can be built with Bazel on Linux. These samples contain a BUILD.bazel file, which is similar to a build.gradle file. The external dependencies are defined in the top level WORKSPACE file.

This is experimental while testing features are being developed in Bazel. To run the tests, please use a development build of Bazel built from master:

$ git clone https://github.com/bazelbuild/bazel
$ cd bazel
$ bazel build //src:bazel # requires local installation of Bazel, please see https://docs.bazel.build/versions/master/install.html`
$ cp bazel-bin/src/bazel /tmp/bazel

Then, to run the tests:

$ git clone https://github.com/google/android-testing
$ cd android-testing

# Edit the path to your local SDK at the top of the WORKSPACE file
$ $EDITOR WORKSPACE

# Test everything in a headless mode
$ /tmp/bazel test //... --spawn_strategy=local

# Test a single test, e.g. ui/espresso/BasicSample/BUILD.bazel
$ /tmp/bazel test //ui/espresso/BasicSample:BasicSampleInstrumentationTest --spawn_strategy=local

# Test everything with GUI enabled
$ /tmp/bazel test //... --action_env=DISPLAY=$DISPLAY

# Test with a local device or emulator. Ensure that `adb devices` lists the device.
$ /tmp/bazel test //... --test_output=streamed --test_arg=--device_broker_type=LOCAL_ADB_SERVER

# If multiple devices are connected, add --device_serial_number=$identifier where $identifier is the name of the device in `adb devices`
$ /tmp/bazel test //... --test_output=streamed --test_arg=--device_broker_type=LOCAL_ADB_SERVER --test_arg=--device_serial_number=$identifier

For more information, check out the tutorial for Building an Android App with Bazel, and the list of Android Rules in the Bazel Build Encyclopedia.

Known issues:

  • Headless mode is unstable in sandboxed mode due to Xvfb issues, so the flag --spawn_strategy=local is required.
  • Building of APKs is supported on Linux, Mac and Windows, but testing is only supported on Linux.
  • android_instrumentation_test.target_device attribute still needs to be specified even if LOCAL_ADB_SERVER is used.
  • If using a local device or emulator, the APKs are not uninstalled automatically after the test. Use this command to remove the packages:
    • adb shell pm list packages com.example.android.testing | cut -d ':' -f 2 | tr -d '\r' | xargs -L1 -t adb uninstall

Please file Bazel related issues against the Bazel repository instead of this repository.

Support

If you've found an error in this sample, please file an issue: https://github.com/googlesamples/android-testing

Patches are encouraged, and may be submitted by forking this project and submitting a pull request through GitHub. Please see CONTRIBUTING.md for more details.

License

Copyright 2015 The Android Open Source Project, Inc.

Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

android-testing's People

Contributors

ardock avatar bootstraponline avatar cdsap avatar fireashes avatar jin avatar josealcerreca avatar marcosdiez avatar nkoroste avatar otw avatar saulmm avatar slinzner avatar sschuberth avatar stefma avatar tiembo avatar tnosadsharkdev avatar trapacska avatar valeraz avatar vinaywadhwa avatar vogella avatar wlowe avatar ytrino avatar zxx714 avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo 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.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.