2013-08-22 4 views
0

Я пытаюсь использовать MonkeyTalk для автоматизации тестов черного ящика в приложении для Android. Проблема, с которой я сталкиваюсь, заключается в том, что у них нет каких-либо документов о ее использовании с Maven. Итак, после многих исследований и попыток многого, я сделал сборку работать. Но мое приложение рушится, когда я устанавливаю агент MonkeyTalk.Мое приложение рушится после установки агента MonkeyTalk

Я не знаю, что-то не так с моей сборкой, или если агент MonkeyTalk несовместим с библиотеками, которые я использую. Итак, вот что я сделал, чтобы построить с мавена:

Во-первых, я загружен MonkeyTalk и установил JAR агента с помощью этой команды:

mvn install:install-file -Dfile=monkeytalk-agent-1.0.53.jar -DgroupId="com.gorillalogic.monkeytalk" -DartifactId="monkeytalk-agent" -Dversion="1.0.53" -Dpackaging="jar" 

Итак, я добавил следующее зависимости:

<dependency> 
    <groupId>org.aspectj</groupId> 
    <artifactId>aspectjrt</artifactId> 
    <version>1.6.2</version> 
</dependency> 

<dependency> 
    <groupId>org.aspectj</groupId> 
    <artifactId>aspectjtools</artifactId> 
    <version>1.6.2</version> 
    <scope>provided</scope> 
</dependency> 

И, так как я не хочу, чтобы агент MonkeyTalk должны быть включены в каждом выпуске, я создал профиль следующим образом:

<profile> 
    <id>monkeytalk</id> 

    <dependencies> 
     <dependency> 
      <groupId>com.gorillalogic.monkeytalk</groupId> 
      <artifactId>monkeytalk-agent</artifactId> 
      <version>1.0.53</version> 
     </dependency> 

    </dependencies> 

    <build> 
     <plugins> 
      <plugin> 
       <groupId>org.codehaus.mojo</groupId> 
       <artifactId>aspectj-maven-plugin</artifactId> 
       <version>1.4</version> 
       <configuration> 
        <source>1.6</source> 
        <target>1.6</target> 
        <aspectLibraries> 
         <aspectLibrary> 
          <groupId>com.gorillalogic.monkeytalk</groupId> 
          <artifactId>monkeytalk-agent</artifactId> 
         </aspectLibrary> 
        </aspectLibraries> 
        <showWeaveInfo>true</showWeaveInfo> 
        <verbose>true</verbose> 
        <Xlint>ignore</Xlint> 
        <outxml>true</outxml> 
       </configuration> 
       <executions> 
        <execution> 
         <!--<phase>process-sources</phase>--> 
         <goals> 
          <goal>compile</goal> 
          <goal>test-compile</goal> 
         </goals> 
        </execution> 
       </executions> 
      </plugin> 
     </plugins> 
    </build> 
</profile> 

С этой конфигурацией сборка работает нормально. Я вижу в журнале, что плагин aspectj настраивает MonkeyTalk. Вот часть журнала:

[INFO] Join point 'method-call(void android.widget.TextView.setText(java.lang.CharSequence))' in Type 'com.devspark.appmsg.AppMsg' (AppMsg.java:144) advised by before advice from 'com.gorillalogic.fonemonkey.aspects.SetText' (monkeytalk-agent-1.0.56.jar!SetText.class:26(from SetText.aj)) 
[INFO] Join point 'method-call(void com.devspark.appmsg.AppMsg.setText(java.lang.CharSequence))' in Type 'com.devspark.appmsg.AppMsg' (AppMsg.java:286) advised by before advice from 'com.gorillalogic.fonemonkey.aspects.SetText' (monkeytalk-agent-1.0.56.jar!SetText.class:26(from SetText.aj)) 
[INFO] Join point 'method-call(void android.widget.TextView.setText(java.lang.CharSequence))' in Type 'com.devspark.appmsg.AppMsg' (AppMsg.java:302) advised by before advice from 'com.gorillalogic.fonemonkey.aspects.SetText' (monkeytalk-agent-1.0.56.jar!SetText.class:26(from SetText.aj)) 

Хорошо, но когда я установить приложение и попытаться открыть его, я могу только открыть первый экран, который является самым простым, имея всего несколько кнопок, которые либо Войти с помощью социальной сети или открыть другую деятельность. Но когда я открываю другое действие, это намного сложнее, приложение падает. И это очень странно, потому что в каждой версии Android он падает с другим исключением.

Это исключение, например, происходит с Android 4.3:

08-22 16:49:54.012: INFO/ActivityManager(534): START u0 {cmp=com.soongz/.ui.CadastroActivity} from pid 17633 
08-22 16:49:54.803: ERROR/AndroidRuntime(17633): FATAL EXCEPTION: main 
     java.lang.RuntimeException: Unable to start activity ComponentInfo{com.soongz/com.soongz.ui.CadastroActivity}: android.util.AndroidRuntimeException: requestFeature() must be called before adding content 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261) 
     at android.app.ActivityThread.access$600(ActivityThread.java:141) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256) 
     at android.os.Handler.dispatchMessage(Handler.java:99) 
     at android.os.Looper.loop(Looper.java:137) 
     at android.app.ActivityThread.main(ActivityThread.java:5103) 
     at java.lang.reflect.Method.invokeNative(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:525) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 
     at dalvik.system.NativeStart.main(Native Method) 
     Caused by: android.util.AndroidRuntimeException: requestFeature() must be called before adding content 
     at com.android.internal.policy.impl.PhoneWindow.requestFeature(PhoneWindow.java:226) 
     at android.app.Activity.requestWindowFeature(Activity.java:3264) 
     at android.support.v7.app.ActionBarActivityDelegateICS.supportRequestWindowFeature(ActionBarActivityDelegateICS.java:126) 
     at android.support.v7.app.ActionBarActivity.supportRequestWindowFeature(ActionBarActivity.java:150) 
     at com.soongz.ui.BaseActionBarActivity.createView(BaseActionBarActivity.java:72) 
     at com.soongz.ui.CadastroActivity.createView(CadastroActivity.java:110) 
     at br.com.cybereagle.androidlibrary.ui.helper.RetainedActivityHelper.onCreate(RetainedActivityHelper.java:42) 
     at br.com.cybereagle.androidlibrary.ui.RetainedRoboActionBarActivity.onCreate(RetainedRoboActionBarActivity.java:45) 
     at android.app.Activity.performCreate(Activity.java:5133) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2175) 
     ... 11 more 
08-22 16:49:54.813: WARN/ActivityManager(534): Force finishing activity com.soongz/.ui.CadastroActivity 
08-22 16:49:54.813: WARN/ActivityManager(534): Force finishing activity com.soongz/.ui.MainActivity 

В Android 2.2, у меня есть исключение:

08-22 17:32:32.503: ERROR/AndroidRuntime(698): FATAL EXCEPTION: main 
     java.lang.NoClassDefFoundError: com.gorillalogic.fonemonkey.automators.AutomationManager 
     at com.gorillalogic.fonemonkey.aspects.SetListener.ajc$after$com_gorillalogic_fonemonkey_aspects_SetListener$1$bfeaeda5(SetListener.aj:30) 
     at com.soongz.service.autenticacao.AbstractAutenticador.<init>(AbstractAutenticador.java:51) 
     at com.soongz.service.autenticacao.AutenticadorFacebook.<init>(AutenticadorFacebook.java:38) 
     at com.soongz.ui.MainActivity.initializeUnretainedInstanceFields(MainActivity.java:54) 
     at br.com.cybereagle.androidlibrary.ui.helper.RetainedActivityHelper.onCreate(RetainedActivityHelper.java:34) 
     at br.com.cybereagle.androidlibrary.ui.RetainedRoboFragmentActivity.onCreate(RetainedRoboFragmentActivity.java:36) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 
     at android.app.ActivityThread.access$2300(ActivityThread.java:125) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 
     at android.os.Handler.dispatchMessage(Handler.java:99) 
     at android.os.Looper.loop(Looper.java:123) 
     at android.app.ActivityThread.main(ActivityThread.java:4627) 
     at java.lang.reflect.Method.invokeNative(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:521) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
     at dalvik.system.NativeStart.main(Native Method) 

ли кто-то с большим опытом с MonkeyTalk знает, почему его агентом является ломать мое приложение? Это моя конфигурация maven?

ответ

1

Если requestFeature не является обязательным, попробуйте удалить строку кода.

Или введите строку кода выше super.onCreate(), как указано в this.

This blog может упоминать ту же проблему.

Смежные вопросы