0

依存性注入 (短剣 2) コードを駆動するいくつかの注釈を使用して、アレクサアプリを構築しようとしています。alexa-sample-skills-testは pomの例を示し、次のコマンドを使用して依存関係のある jar を構築するように指示します。

mvn assembly:assembly -DdescriptorId=jar-with-dependencies package

上記を使用したビルドは、このリンクにリストされている例外と出力で失敗します。Maven docsを少し掘り下げた後、assembly:assembly ゴールは、大混乱を引き起こす可能性のある非標準のビルド プロセスを使用していることがわかりました。代わりに、maven assembly-plugin docs では、assembly:single ゴールを使用することを推奨しています。したがって、代わりに次のコマンドを使用します。

mvn assembly:single -DdescriptorId=jar-with-dependencies package

出来上がり..コードのコンパイルとリンクはうまくいきます。[project-name]-jar-with-dependencies.jar ファイルを取得します。しかし、Amazon サーバーに jar をアップロードしてスキルをテストしようとすると、テストが失敗します。ログには、クラス: echo.client.AccountInfoStreamHandler が見つからなかった (ClassNotFoundException) と示されています。このクラスは、ルート ランチャー クラスに発生するだけだと思います。

ここで、dagger 2 のすべての依存関係を削除し、最も単純なコード ベースで同じことを繰り返します。最初の Maven コマンド (assembly:assembly) が機能します。2 番目の Maven コマンド (assembly:single) は、同じ「ClassNotFoundException」エラーで失敗します。私は何を間違っていますか?私はmavenにあまり詳しくありません.mavenコマンドのトラブルシューティングを試みるのはこれが初めてです。提案、指針、推奨事項は大歓迎です。

参考までに、POM ファイルは次のとおりです。

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.apil.echo.accountant</groupId>
  <artifactId>echo-device-client</artifactId>
  <packaging>jar</packaging>
  <version>1.0</version>
  <name>Echo Device Client</name>

  <repositories>
    <repository>
      <id>alexa-skills-kit-repo</id>
      <url>file://${project.basedir}/repo</url>
    </repository>
    <repository>
      <id>Maven Central</id>
      <url>http://repo1.maven.org/maven2/</url>
    </repository>
  </repositories>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.12</version>
      <scope>test</scope>
    </dependency>

    <dependency>
      <groupId>org.powermock</groupId>
      <artifactId>powermock-module-junit4</artifactId>
      <version>1.6.4</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.powermock</groupId>
      <artifactId>powermock-api-mockito</artifactId>
      <version>1.6.4</version>
      <scope>test</scope>
    </dependency>

    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-core</artifactId>
      <version>2.5.3</version>
    </dependency>

    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-annotations</artifactId>
      <version>2.5.3</version>
    </dependency>

    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>2.5.3</version>
    </dependency>

    <dependency>
      <groupId>com.plaid</groupId>
      <artifactId>plaid-java</artifactId>
      <version>0.2.12</version>
    </dependency>
    <dependency>
      <groupId>alexa-skills-kit</groupId>
      <artifactId>alexa-skills-kit</artifactId>
      <version>1.1</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>org.eclipse.jetty</groupId>
      <artifactId>jetty-server</artifactId>
      <version>9.0.6.v20130930</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>org.eclipse.jetty</groupId>
      <artifactId>jetty-servlet</artifactId>
      <version>9.0.6.v20130930</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>log4j</groupId>
      <artifactId>log4j</artifactId>
      <version>1.2.17</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-api</artifactId>
      <version>1.7.10</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>org.apache.commons</groupId>
      <artifactId>commons-lang3</artifactId>
      <version>3.3.2</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>org.apache.directory.studio</groupId>
      <artifactId>org.apache.commons.io</artifactId>
      <version>2.4</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>com.amazonaws</groupId>
      <artifactId>aws-lambda-java-core</artifactId>
      <version>1.0.0</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>com.amazonaws</groupId>
      <artifactId>aws-java-sdk-dynamodb</artifactId>
      <version>1.9.40</version>
    </dependency>

    <!-- using mockito for test -->
    <dependency>
      <groupId>org.mockito</groupId>
      <artifactId>mockito-all</artifactId>
      <version>1.9.5</version>
      <scope>test</scope>
    </dependency>

      <dependency>
          <groupId>com.google.dagger</groupId>
          <artifactId>dagger</artifactId>
          <version>2.0</version>
      </dependency>
      <dependency>
          <groupId>com.google.dagger</groupId>
          <artifactId>dagger-compiler</artifactId>
          <version>2.0</version>
          <optional>true</optional>
      </dependency>

  </dependencies>

  <properties>
    <property name="disableRequestSignatureCheck" value="false"/>
    <property name="supportedApplicationIds" value=""/>
    <property name="timestampTolerance" value="150"/>
  </properties>

  <build>
    <pluginManagement>
      <plugins>
        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.3</version>
          <configuration>
            <source>1.7</source>
            <target>1.7</target>
          </configuration>
        </plugin>

        <plugin>
          <groupId>org.codehaus.mojo</groupId>
          <artifactId>exec-maven-plugin</artifactId>
          <version>1.2.1</version>
          <configuration>
            <mainClass>Launcher</mainClass>
            <systemProperties>
              <systemProperty>
                <key>javax.net.ssl.keyStore</key>
                <value>/insert/your/path/java-keystore.jks</value>
              </systemProperty>
              <systemProperty>
                <key>javax.net.ssl.keyStorePassword</key>
                <value>insert_your_password</value>
              </systemProperty>
              <systemProperty>
                <key>com.amazon.speech.speechlet.servlet.disableRequestSignatureCheck</key>
                <value>${disableRequestSignatureCheck}</value>
              </systemProperty>
              <systemProperty>
                <key>com.amazon.speech.speechlet.servlet.supportedApplicationIds</key>
                <value>${supportedApplicationIds}</value>
              </systemProperty>
              <systemProperty>
                <key>com.amazon.speech.speechlet.servlet.timestampTolerance</key>
                <value>${timestampTolerance}</value>
              </systemProperty>
            </systemProperties>
          </configuration>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
</project>
4

1 に答える 1

0

alexa-sample-skills-test 用に最近提供された gradle ビルド スクリプトを使用することになりました。予備ビルド インスペクションでは、必要なクラス echo.client.[Class..] が結果のビルドに存在することが示されています。

上記のmavenコマンドの結果として得られたuber-jarを調べたところ、次のことに気付きました

mvn assembly:assembly ...

クラスが欠落している echo.client パッケージを含む jar が生成されました。でも、

mvn assembly:single...

echo.client パッケージ、またはパッケージ内で定義されたアプリケーション クラスのいずれも持たない jar が生成されました。したがって、ClassNotFoundException を取得していました。なぜこれが起こったのか、私はまだ理解していません。しかし、ここから「gradle」に切り替える機は熟していると思います...

于 2016-04-07T17:26:11.073 に答える