diff options
author | Android (Google) Code Review <android-gerrit@google.com> | 2009-09-09 22:00:52 -0400 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2009-09-09 22:00:52 -0400 |
commit | 92df676496d1cfd0b2c26cbef07da93859990717 (patch) | |
tree | f520182f3653019ac8716da711dbb9eba817d095 /scripts | |
parent | 38612f276ecbdc5c5f53105f7f5fc78252d30ef1 (diff) | |
parent | b0b67269c3b92817f2794dbb2020c663b0509393 (diff) | |
download | sdk-92df676496d1cfd0b2c26cbef07da93859990717.zip sdk-92df676496d1cfd0b2c26cbef07da93859990717.tar.gz sdk-92df676496d1cfd0b2c26cbef07da93859990717.tar.bz2 |
Merge change 23594 into eclair
* changes:
Add ant-based code coverage support to Android SDK
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/android_rules.xml | 172 | ||||
-rw-r--r-- | scripts/android_test_rules.xml | 131 | ||||
-rw-r--r-- | scripts/build.template | 1 |
3 files changed, 239 insertions, 65 deletions
diff --git a/scripts/android_rules.xml b/scripts/android_rules.xml index 64f0e39..bdb9834 100644 --- a/scripts/android_rules.xml +++ b/scripts/android_rules.xml @@ -27,36 +27,46 @@ <property name="android.tools.dir" location="${sdk.dir}/tools" /> <!-- Input directories --> - <property name="source.dir" location="src" /> - <property name="gen.dir" location="gen" /> - <property name="resource.dir" location="res" /> - <property name="asset.dir" location="assets" /> - - <!-- Directory for the 3rd party java libraries --> - <property name="external.libs.dir" location="libs" /> + <property name="source.dir" value="src" /> + <property name="source.absolute.dir" location="${source.dir}" /> + <property name="gen.dir" value="gen" /> + <property name="gen.absolute.dir" location="${gen.dir}" /> + <property name="resource.dir" value="res" /> + <property name="resource.absolute.dir" location="${resource.dir}" /> + <property name="asset.dir" value="assets" /> + <property name="asset.absolute.dir" location="${asset.dir}" /> + + <!-- Directory for the third party java libraries --> + <property name="external.libs.dir" value="libs" /> + <property name="external.libs.absolute.dir" location="${external.libs.dir}" /> + + <!-- In this file it is just alias for external.libs.absolute.dir. It is used for + reusability though, when calling ant targets in this file from other files. + However, it is a temporary solution. --> + <property name="external.jars" location="${external.libs.absolute.dir}" /> <!-- Directory for the native libraries --> - <property name="native.libs.dir" location="libs" /> + <property name="native.libs.dir" value="libs" /> + <property name="native.libs.absolute.dir" location="${native.libs.dir}" /> <!-- Output directories --> - <property name="gen.dir" location="gen" /> - <property name="out.dir" location="bin" /> - <property name="out.classes.dir" location="${out.dir}/classes" /> - - <!-- Out directory for a parent project if this project is an instrumentation project --> - <property name="main.out.dir" location="../${out.dir}" /> - <property name="main.out.classes.dir" location="${main.out.dir}/classes" /> + <property name="out.dir" value="bin" /> + <property name="out.absolute.dir" location="${out.dir}" /> + <property name="out.classes.dir" value="${out.dir}/classes" /> + <property name="out.classes.absolute.dir" location="${out.classes.dir}" /> <!-- Intermediate files --> <property name="dex.file.name" value="classes.dex" /> - <property name="intermediate.dex.file" location="${out.dir}/${dex.file.name}" /> + <property name="intermediate.dex.file" location="${out.absolute.dir}/${dex.file.name}" /> <!-- The final package file to generate --> - <property name="out.debug.unaligned.package" location="${out.dir}/${ant.project.name}-debug-unaligned.apk" /> - <property name="out.debug.package" location="${out.dir}/${ant.project.name}-debug.apk" /> - <property name="out.unsigned.package" location="${out.dir}/${ant.project.name}-unsigned.apk" /> - <property name="out.unaligned.package" location="${out.dir}/${ant.project.name}-unaligned.apk" /> - <property name="out.release.package" location="${out.dir}/${ant.project.name}-release.apk" /> + <property name="out.debug.unaligned.package" + location="${out.absolute.dir}/${ant.project.name}-debug-unaligned.apk" /> + <property name="out.debug.package" location="${out.absolute.dir}/${ant.project.name}-debug.apk" /> + <property name="out.unsigned.package" location="${out.absolute.dir}/${ant.project.name}-unsigned.apk" /> + <property name="out.unaligned.package" + location="${out.absolute.dir}/${ant.project.name}-unaligned.apk" /> + <property name="out.release.package" location="${out.absolute.dir}/${ant.project.name}-release.apk" /> <!-- Tools --> <condition property="exe" value=".exe" else=""><os family="windows" /></condition> @@ -68,11 +78,11 @@ <!-- Creates the output directories if they don't exist yet. --> <target name="-dirs"> <echo>Creating output directories if needed...</echo> - <mkdir dir="${resource.dir}" /> - <mkdir dir="${external.libs.dir}" /> - <mkdir dir="${gen.dir}" /> - <mkdir dir="${out.dir}" /> - <mkdir dir="${out.classes.dir}" /> + <mkdir dir="${resource.absolute.dir}" /> + <mkdir dir="${external.libs.absolute.dir}" /> + <mkdir dir="${gen.absolute.dir}" /> + <mkdir dir="${out.absolute.dir}" /> + <mkdir dir="${out.classes.absolute.dir}" /> </target> <!-- Generates the R.java file for this project's resources. --> @@ -82,11 +92,11 @@ <arg value="package" /> <arg value="-m" /> <arg value="-J" /> - <arg path="${gen.dir}" /> + <arg path="${gen.absolute.dir}" /> <arg value="-M" /> <arg path="AndroidManifest.xml" /> <arg value="-S" /> - <arg path="${resource.dir}" /> + <arg path="${resource.absolute.dir}" /> <arg value="-I" /> <arg path="${android.jar}" /> </exec> @@ -97,9 +107,9 @@ <echo>Compiling aidl files into Java classes...</echo> <apply executable="${aidl}" failonerror="true"> <arg value="-p${android.aidl}" /> - <arg value="-I${source.dir}" /> - <arg value="-o${gen.dir}" /> - <fileset dir="${source.dir}"> + <arg value="-I${source.absolute.dir}" /> + <arg value="-o${gen.absolute.dir}" /> + <fileset dir="${source.absolute.dir}"> <include name="**/*.aidl" /> </fileset> </apply> @@ -108,27 +118,48 @@ <!-- Compiles this project's .java files into .class files. --> <target name="compile" depends="-resource-src, -aidl" description="Compiles project's .java files into .class files"> + <!-- Allows to inject additional classpath from another (build|property) file. + As ant properties are immutable, the injected value will have priority + over the one defined below --> + <property name="extensible.classpath" value="." /> <javac encoding="ascii" target="1.5" debug="true" extdirs="" - destdir="${out.classes.dir}" - bootclasspathref="android.target.classpath"> - <src path="${source.dir}" /> - <src path="${gen.dir}" /> + destdir="${out.classes.absolute.dir}" + bootclasspathref="android.target.classpath" + verbose="false" classpath="${extensible.classpath}"> + <src path="${source.absolute.dir}" /> + <src path="${gen.absolute.dir}" /> <classpath> - <fileset dir="${external.libs.dir}" includes="*.jar" /> - <pathelement path="${main.out.classes.dir}" /> + <fileset dir="${external.libs.absolute.dir}" includes="*.jar" /> </classpath> - </javac> + </javac> </target> + <!-- Configurable macro, which allows to pass as parameters output directory, + output dex filename and external libraries to dex (optional) --> + <macrodef name="dex-helper"> + <attribute name="out.absolute.dir" /> + <attribute name="out.dex.file" /> + <element name="external-libs" optional="yes" /> + <sequential> + <echo>Converting compiled files and external libraries into @{out.dex.file}...</echo> + <apply executable="${dx}" failonerror="true" parallel="true"> + <arg value="--dex" /> + <arg value="--output=@{out.dex.file}" /> + <arg path="@{out.absolute.dir}" /> + <external-libs /> + </apply> + </sequential> + </macrodef> + <!-- Converts this project's .class files into .dex files --> <target name="-dex" depends="compile"> - <echo>Converting compiled files and external libraries into ${out.dir}/${dex.file.name}...</echo> - <apply executable="${dx}" failonerror="true" parallel="true"> - <arg value="--dex" /> - <arg value="--output=${intermediate.dex.file}" /> - <arg path="${out.classes.dir}" /> - <fileset dir="${external.libs.dir}" includes="*.jar" /> - </apply> + <dex-helper out.absolute.dir="${out.absolute.dir}/classes" + out.dex.file="${intermediate.dex.file}"> + <external-libs> + <!-- Temporary solution, before <jarfile> in <apkbuilder> is ready --> + <fileset dir="${external.jars}" includes="*.jar" /> + </external-libs> + </dex-helper> </target> <!-- Puts the project's resources into the output package file @@ -141,10 +172,10 @@ <aaptexec executable="${aapt}" command="package" manifest="AndroidManifest.xml" - resources="${resource.dir}" - assets="${asset.dir}" + resources="${resource.absolute.dir}" + assets="${asset.absolute.dir}" androidjar="${android.jar}" - outfolder="${out.dir}" + outfolder="${out.absolute.dir}" basename="${ant.project.name}" /> </target> @@ -152,14 +183,14 @@ This requires the property sign.package to be set to true or false. --> <target name="-package"> <apkbuilder - outfolder="${out.dir}" + outfolder="${out.absolute.dir}" basename="${ant.project.name}" signed="${sign.package}" verbose="true"> <file path="${intermediate.dex.file}" /> - <sourcefolder path="${source.dir}" /> - <jarfolder path="${external.libs.dir}" /> - <nativefolder path="${native.libs.dir}" /> + <sourcefolder path="${source.absolute.dir}" /> + <jarfolder path="${external.jars}" /> + <nativefolder path="${native.libs.absolute.dir}" /> </apkbuilder> </target> @@ -171,8 +202,8 @@ <property name="sign.package" value="true" /> </target> - <target name="debug" depends="-dex, -package-resources, -debug-sign, -package" - description="Builds the application and signs it with a debug key."> + <!-- Builds debug output package, provided all the necessary files are already dexed --> + <target name="-debug-no-dex" depends="-package-resources, -debug-sign, -package"> <echo>Running zip align on final apk...</echo> <exec executable="${zipalign}" failonerror="true"> <arg value="-f" /> @@ -183,8 +214,10 @@ <echo>Debug Package: ${out.debug.package}</echo> </target> - <target name="-release-package" depends="-dex, -package-resources, -no-sign, -package"> - </target> + <target name="debug" depends="-dex, -debug-no-dex" + description="Builds the application and signs it with a debug key." /> + + <target name="-release-package" depends="-dex, -package-resources, -no-sign, -package" /> <target name="-release-check"> <condition property="release.sign"> @@ -202,8 +235,8 @@ </target> <target name="release" depends="-release-package, -release-nosign" if="release-sign" - description="Builds the application. The generated apk file must be signed before it is published."> - + description="Builds the application. The generated apk file must be signed before + it is published."> <!-- Gets passwords --> <input message="Please enter keystore password (store:${key.store}):" @@ -234,8 +267,7 @@ </target> <!-- Installs the package on the default emulator/device --> - <target name="install" depends="debug" - description="Installs/reinstalls the debug package onto a running emulator or device. This can only be used if the application has not yet been installed."> + <target name="-install-no-deps"> <echo>Installing ${out.debug.package} onto default emulator or device...</echo> <exec executable="${adb}" failonerror="true"> <arg value="install" /> @@ -244,6 +276,13 @@ </exec> </target> + <target name="install" depends="debug, -install-no-deps" + description="Installs/reinstalls the debug package onto a running + emulator or device. If the application was previously installed, + the signatures must match." /> + + <target name="-install-no-dex" depends="-debug-no-dex, -install-no-deps" /> + <target name="-uninstall-check"> <condition property="uninstall.run"> <isset property="application.package" /> @@ -251,11 +290,14 @@ </target> <target name="-uninstall-error" depends="-uninstall-check" unless="uninstall.run"> - <echo>Unable to run 'ant uninstall', application.package is not defined in build.properties</echo> + <echo> + Unable to run 'ant uninstall', application.package is not defined in build.properties + </echo> </target> <!-- Uninstalls the package from the default emulator/device --> - <target name="uninstall" depends="-uninstall-error" if="uninstall.run" description="Uninstalls the application from a running emulator or device."> + <target name="uninstall" depends="-uninstall-error" if="uninstall.run" + description="Uninstalls the application from a running emulator or device."> <echo>Uninstalling ${application.package} from the default emulator or device...</echo> <exec executable="${adb}" failonerror="true"> <arg value="uninstall" /> @@ -264,8 +306,8 @@ </target> <target name="clean" description="Removes output files created by other targets."> - <delete dir="${out.dir}" /> - <delete dir="${gen.dir}" /> + <delete dir="${out.absolute.dir}" /> + <delete dir="${gen.absolute.dir}" /> </target> <target name="help"> @@ -278,7 +320,7 @@ <echo> debug: Builds the application and signs it with a debug key.</echo> <echo> release: Builds the application. The generated apk file must be</echo> <echo> signed before it is published.</echo> - <echo> install: Installs/reinstall the debug package onto a running</echo> + <echo> install: Installs/reinstalls the debug package onto a running</echo> <echo> emulator or device.</echo> <echo> If the application was previously installed, the</echo> <echo> signatures must match.</echo> diff --git a/scripts/android_test_rules.xml b/scripts/android_test_rules.xml new file mode 100644 index 0000000..dbad32d --- /dev/null +++ b/scripts/android_test_rules.xml @@ -0,0 +1,131 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project name="android_test_rules" default="run-tests"> + + <import file="android_rules.xml" /> + + <!-- Existence of this property in build.properties or build.xml is an assertion for the test + project + <property name="tested.project.dir" value=".." /> --> + <property name="tested.project.absolute.dir" location="${tested.project.dir}" /> + <property name="instrumentation.dir" value="instru" /> + <property name="instrumentation.absolute.dir" location="${instrumentation.dir}" /> + + <property name="test.runner" value="android.test.InstrumentationTestRunner" /> + <property name="application.package.to.instrument" value="${application.package}.tests" /> + + <!-- Enables adding tested project classes location to test project classpath --> + <property name="extensible.classpath" value="${tested.project.absolute.dir}/bin/classes" /> + + <!-- TODO: make it more configurable in the next CL's - now it is default for auto-generated + project --> + <property name="emma.dump.file" value="/data/data/${application.package}/files/coverage.ec" /> + + <!-- Emma configuration --> + <property name="emma.dir" value="${sdk.dir}/tools/lib" /> + <path id="emma.lib"> + <pathelement location="${emma.dir}/emma.jar" /> + <pathelement location="${emma.dir}/emma_ant.jar" /> + </path> + <taskdef resource="emma_ant.properties" classpathref="emma.lib" /> + <!-- End of emma configuration --> + + <!-- Runs 'compile' target for tested project --> + <target name="-compile-tested-project"> + <subant target="compile"> + <fileset dir="${tested.project.absolute.dir}" includes="build.xml" /> + </subant> + </target> + + <!-- Emma-instruments tested project classes (compiles the tested project if necessary) + and writes instrumented classes to ${instrumentation.absolute.dir}/classes --> + <target name="-emma-instrument" depends="-compile-tested-project"> + <echo>Instrumenting classes from ${instrumentation.dir}/${out.dir}/classes...</echo> + <!-- It only instruments class files, not any external libs --> + <emma enabled="true"> + <instr verbosity="verbose" + mode="copy" + instrpath="${tested.project.absolute.dir}/${out.dir}/classes" + outdir="${instrumentation.absolute.dir}/classes"> + </instr> + <!-- TODO: exclusion filters on R*.class and allowing custom exclusion from + user defined file --> + </emma> + </target> + + <!-- Dexes emma-instrumented classes --> + <target name="-dex-instrumented" depends="-emma-instrument"> + <dex-helper out.absolute.dir="${instrumentation.absolute.dir}/classes" + out.dex.file="${instrumentation.absolute.dir}/${dex.file.name}"> + <external-libs> + <fileset dir="${external.libs.dir}" includes="*.jar" /> + <fileset dir="${emma.dir}"> + <include name="emma_device.jar" /> + </fileset> + </external-libs> + </dex-helper> + </target> + + <!-- Installs instrumented package on the default emulator/device --> + <target name="-install-instrumented" depends="-dex-instrumented"> + <subant target="-install-no-dex"> + <property name="out.absolute.dir" value="${instrumentation.absolute.dir}" /> + <property name="external.jars" location="${emma.dir}/emma_device.jar" /> + <fileset dir="${tested.project.absolute.dir}" includes="build.xml" /> + </subant> + </target> + + <macrodef name="run-tests-helper"> + <attribute name="emma.enabled" default="false" /> + <sequential> + <echo>Running tests ...</echo> + <exec executable="${adb}" failonerror="true"> + <arg value="shell" /> + <arg value="am" /> + <arg value="instrument" /> + <arg value="-w" /> + <arg value="-e" /> + <arg value="coverage" /> + <arg value="@{emma.enabled}" /> + <arg value="${application.package.to.instrument}/${test.runner}" /> + </exec> + </sequential> + </macrodef> + + <!-- Ensures that tested project is installed on the device before we run the tests. + Used for ordinary tests, without coverage measurement --> + <target name="-install-tested-project"> + <subant target="install"> + <fileset dir="${tested.project.absolute.dir}" includes="build.xml" /> + </subant> + </target> + + <target name="run-tests" depends="-install-tested-project, install" + description="Runs tests from the package defined in test.package property"> + <run-tests-helper /> + </target> + + <target name="coverage" depends="-install-instrumented, install" + description="Runs test on instrumented code and generates code coverage report"> + <run-tests-helper emma.enabled="true" /> + <echo>Downloading coverage file into project directory...</echo> + <exec executable="${adb}" failonerror="true"> + <arg value="pull" /> + <arg value="${emma.dump.file}" /> + <arg value="coverage.ec" /> + </exec> + <echo>Extracting coverage report...</echo> + <emma> + <report sourcepath="${tested.project.absolute.dir}/${source.dir}" + verbosity="verbose"> + <!-- TODO: report.dir or something like should be introduced if necessary --> + <infileset dir="."> + <include name="coverage.ec" /> + <include name="coverage.em" /> + </infileset> + <!-- TODO: reports in other, indicated by user formats --> + <html outfile="coverage.html" /> + </report> + </emma> + </target> + +</project> diff --git a/scripts/build.template b/scripts/build.template index ca15954..3959c57 100644 --- a/scripts/build.template +++ b/scripts/build.template @@ -63,4 +63,5 @@ build steps are used. --> <setup /> + </project> |