Author: tchemit Date: 2009-09-06 21:06:37 +0200 (Sun, 06 Sep 2009) New Revision: 18 Added: maven-redmine-plugin/ maven-redmine-plugin/trunk/ maven-redmine-plugin/trunk/LICENSE.txt maven-redmine-plugin/trunk/README.txt maven-redmine-plugin/trunk/changelog.txt maven-redmine-plugin/trunk/pom.xml maven-redmine-plugin/trunk/src/ maven-redmine-plugin/trunk/src/main/ maven-redmine-plugin/trunk/src/main/java/ maven-redmine-plugin/trunk/src/main/java/org/ maven-redmine-plugin/trunk/src/main/java/org/nuiton/ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/RedmineSession.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Issue.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Project.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Tracker.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/User.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Version.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/AbstractGetProjectDataMojo.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/AbstractRedmineMojo.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/DataNotFoundException.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GenerateChangesMojo.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GetProjectDataMojo.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GetProjectVersionDataMojo.java maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/RedmineReportMojo.java maven-redmine-plugin/trunk/src/main/resources/ maven-redmine-plugin/trunk/src/site/ maven-redmine-plugin/trunk/src/site/apt/ maven-redmine-plugin/trunk/src/site/apt/Todo.apt maven-redmine-plugin/trunk/src/site/apt/index.apt maven-redmine-plugin/trunk/src/site/apt/usage.apt maven-redmine-plugin/trunk/src/site/site.xml maven-redmine-plugin/trunk/src/test/ maven-redmine-plugin/trunk/src/test/java/ maven-redmine-plugin/trunk/src/test/java/org/ maven-redmine-plugin/trunk/src/test/java/org/nuiton/ maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/ maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/RedmineSessionTest.java maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/ maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/AbstractRedmineMojoTest.java maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GenerateChangesMojoTest.java maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GetProjectDataMojoTest.java maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest.java maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/RedmineReportMojoTest.java maven-redmine-plugin/trunk/src/test/resources/ maven-redmine-plugin/trunk/src/test/resources/org/ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GenerateChangesMojoTest/ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GenerateChangesMojoTest/generate-changes.xml maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-trackers.xml maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-users.xml maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-versions.xml maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project.xml maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version-files.xml maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version-issues.xml maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version.xml maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/RedmineReportMojoTest/ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/RedmineReportMojoTest/redmine-report.xml Log: initial import Property changes on: maven-redmine-plugin ___________________________________________________________________ Added: svn:ignore + target Property changes on: maven-redmine-plugin/trunk ___________________________________________________________________ Added: svn:ignore + target Added: maven-redmine-plugin/trunk/LICENSE.txt =================================================================== --- maven-redmine-plugin/trunk/LICENSE.txt (rev 0) +++ maven-redmine-plugin/trunk/LICENSE.txt 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,166 @@ + GNU LESSER GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/> + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + + This version of the GNU Lesser General Public License incorporates +the terms and conditions of version 3 of the GNU General Public +License, supplemented by the additional permissions listed below. + + 0. Additional Definitions. + + As used herein, "this License" refers to version 3 of the GNU Lesser +General Public License, and the "GNU GPL" refers to version 3 of the GNU +General Public License. + + "The Library" refers to a covered work governed by this License, +other than an Application or a Combined Work as defined below. + + An "Application" is any work that makes use of an interface provided +by the Library, but which is not otherwise based on the Library. +Defining a subclass of a class defined by the Library is deemed a mode +of using an interface provided by the Library. + + A "Combined Work" is a work produced by combining or linking an +Application with the Library. The particular version of the Library +with which the Combined Work was made is also called the "Linked +Version". + + The "Minimal Corresponding Source" for a Combined Work means the +Corresponding Source for the Combined Work, excluding any source code +for portions of the Combined Work that, considered in isolation, are +based on the Application, and not on the Linked Version. + + The "Corresponding Application Code" for a Combined Work means the +object code and/or source code for the Application, including any data +and utility programs needed for reproducing the Combined Work from the +Application, but excluding the System Libraries of the Combined Work. + + 1. Exception to Section 3 of the GNU GPL. + + You may convey a covered work under sections 3 and 4 of this License +without being bound by section 3 of the GNU GPL. + + 2. Conveying Modified Versions. + + If you modify a copy of the Library, and, in your modifications, a +facility refers to a function or data to be supplied by an Application +that uses the facility (other than as an argument passed when the +facility is invoked), then you may convey a copy of the modified +version: + + a) under this License, provided that you make a good faith effort to + ensure that, in the event an Application does not supply the + function or data, the facility still operates, and performs + whatever part of its purpose remains meaningful, or + + b) under the GNU GPL, with none of the additional permissions of + this License applicable to that copy. + + 3. Object Code Incorporating Material from Library Header Files. + + The object code form of an Application may incorporate material from +a header file that is part of the Library. You may convey such object +code under terms of your choice, provided that, if the incorporated +material is not limited to numerical parameters, data structure +layouts and accessors, or small macros, inline functions and templates +(ten or fewer lines in length), you do both of the following: + + a) Give prominent notice with each copy of the object code that the + Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the object code with a copy of the GNU GPL and this license + document. + + 4. Combined Works. + + You may convey a Combined Work under terms of your choice that, +taken together, effectively do not restrict modification of the +portions of the Library contained in the Combined Work and reverse +engineering for debugging such modifications, if you also do each of +the following: + + a) Give prominent notice with each copy of the Combined Work that + the Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the Combined Work with a copy of the GNU GPL and this license + document. + + c) For a Combined Work that displays copyright notices during + execution, include the copyright notice for the Library among + these notices, as well as a reference directing the user to the + copies of the GNU GPL and this license document. + + d) Do one of the following: + + 0) Convey the Minimal Corresponding Source under the terms of this + License, and the Corresponding Application Code in a form + suitable for, and under terms that permit, the user to + recombine or relink the Application with a modified version of + the Linked Version to produce a modified Combined Work, in the + manner specified by section 6 of the GNU GPL for conveying + Corresponding Source. + + 1) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (a) uses at run time + a copy of the Library already present on the user's computer + system, and (b) will operate properly with a modified version + of the Library that is interface-compatible with the Linked + Version. + + e) Provide Installation Information, but only if you would otherwise + be required to provide such information under section 6 of the + GNU GPL, and only to the extent that such information is + necessary to install and execute a modified version of the + Combined Work produced by recombining or relinking the + Application with a modified version of the Linked Version. (If + you use option 4d0, the Installation Information must accompany + the Minimal Corresponding Source and Corresponding Application + Code. If you use option 4d1, you must provide the Installation + Information in the manner specified by section 6 of the GNU GPL + for conveying Corresponding Source.) + + 5. Combined Libraries. + + You may place library facilities that are a work based on the +Library side by side in a single library together with other library +facilities that are not Applications and are not covered by this +License, and convey such a combined library under terms of your +choice, if you do both of the following: + + a) Accompany the combined library with a copy of the same work based + on the Library, uncombined with any other library facilities, + conveyed under the terms of this License. + + b) Give prominent notice with the combined library that part of it + is a work based on the Library, and explaining where to find the + accompanying uncombined form of the same work. + + 6. Revised Versions of the GNU Lesser General Public License. + + The Free Software Foundation may publish revised and/or new versions +of the GNU Lesser General Public License from time to time. Such new +versions will be similar in spirit to the present version, but may +differ in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the +Library as you received it specifies that a certain numbered version +of the GNU Lesser General Public License "or any later version" +applies to it, you have the option of following the terms and +conditions either of that published version or of any later version +published by the Free Software Foundation. If the Library as you +received it does not specify a version number of the GNU Lesser +General Public License, you may choose any version of the GNU Lesser +General Public License ever published by the Free Software Foundation. + + If the Library as you received it specifies that a proxy can decide +whether future versions of the GNU Lesser General Public License shall +apply, that proxy's public statement of acceptance of any version is +permanent authorization for you to choose that version for the +Library. + Added: maven-redmine-plugin/trunk/README.txt =================================================================== --- maven-redmine-plugin/trunk/README.txt (rev 0) +++ maven-redmine-plugin/trunk/README.txt 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,2 @@ +To deploy new version of pom: mvn deploy +To install localy: mvn install Added: maven-redmine-plugin/trunk/changelog.txt =================================================================== --- maven-redmine-plugin/trunk/changelog.txt (rev 0) +++ maven-redmine-plugin/trunk/changelog.txt 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,5 @@ +maven-redmine-plugin (1.0.0-SNAPSHOT) stable; urgency=low + + * //TODO_FILL_ME + + -- author -- date -R Added: maven-redmine-plugin/trunk/pom.xml =================================================================== --- maven-redmine-plugin/trunk/pom.xml (rev 0) +++ maven-redmine-plugin/trunk/pom.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,541 @@ +<?xml version="1.0" encoding="UTF-8"?> +<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> + + <!-- ************************************************************* --> + <!-- *** POM Relationships *************************************** --> + <!-- ************************************************************* --> + + <groupId>org.nuiton</groupId> + <artifactId>maven-redmine-plugin</artifactId> + <version>1.0.0-SNAPSHOT</version> + + <dependencies> + + <dependency> + <groupId>org.nuiton</groupId> + <artifactId>maven-helper-plugin</artifactId> + <version>${helper.version}</version> + <scope>compile</scope> + </dependency> + + <!-- FIXME si on ne le rajoute pas, on se retrouve avec la version 1.1 qui ne convient pas --> + <dependency> + <groupId>org.codehaus.plexus</groupId> + <artifactId>plexus-utils</artifactId> + <version>1.5.15</version> + <scope>compile</scope> + </dependency> + + <dependency> + <groupId>org.apache.maven</groupId> + <artifactId>maven-project</artifactId> + <version>${maven.version}</version> + <scope>provided</scope> + </dependency> + + <dependency> + <groupId>org.apache.maven</groupId> + <artifactId>maven-plugin-api</artifactId> + <version>${maven.version}</version> + <scope>provided</scope> + </dependency> + <dependency> + <groupId>org.sonatype.plexus</groupId> + <artifactId>plexus-sec-dispatcher</artifactId> + <version>1.3.1</version> + </dependency> + + <dependency> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-changes-plugin</artifactId> + <version>2.1</version> + </dependency> + <dependency> + <groupId>org.apache.httpcomponents</groupId> + <artifactId>httpclient</artifactId> + <version>4.0</version> + </dependency> + + <!-- tests dependencies --> + + <dependency> + <groupId>org.nuiton</groupId> + <artifactId>maven-helper-plugin</artifactId> + <version>${helper.version}</version> + <scope>test</scope> + <classifier>tests</classifier> + </dependency> + + <dependency> + <groupId>org.apache.maven.shared</groupId> + <artifactId>maven-plugin-testing-harness</artifactId> + <version>1.1</version> + <scope>test</scope> + </dependency> + + <dependency> + <groupId>junit</groupId> + <artifactId>junit</artifactId> + <version>4.6</version> + <scope>test</scope> + </dependency> + + </dependencies> + + <!-- ************************************************************* --> + <!-- *** Project Information ************************************* --> + <!-- ************************************************************* --> + <name>Redmine maven plugin (new one)</name> + + <description>A plugin to interacts with Redmine's server</description> + + <inceptionYear>2009</inceptionYear> + + <url>http://maven-site.nuiton.org/sandbox/maven-redmine-plugin</url> + + <licenses> + <license> + <name>Lesser General Public License (LGPL)</name> + <url>${maven.license.file}</url> + <distribution>local</distribution> + </license> + </licenses> + + <developers> + + <developer> + <name>Tony Chemit</name> + <id>tchemit</id> + <email>chemit@codelutin.com</email> + <organization>CodeLutin</organization> + <timezone>+2</timezone> + <roles> + <role>Développeur</role> + </roles> + </developer> + + </developers> + + <organization> + <name>CodeLutin</name> + <url>http://www.codelutin.com/</url> + </organization> + + <!-- ************************************************************* --> + <!-- *** Build Settings ****************************************** --> + <!-- ************************************************************* --> + + <packaging>maven-plugin</packaging> + + <properties> + + <!-- the redmine plateform used (nuiton.org or chorem.org) --> + <platform>nuiton.org</platform> + + <!-- a proprerty to define the id of the project, in a multi-module + project, you must use a hard-cored value, otherwise for modules + the artifactId will be expanded , otherwise, no need to override it + --> + <projectId>${project.artifactId}</projectId> + + <!-- a property to define list id --> + <listId>${projectId}</listId> + + <!-- java level is 1.6 --> + <maven.compile.source>1.6</maven.compile.source> + <maven.compile.target>1.6</maven.compile.target> + + <!-- default encoding --> + <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> + <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> + + <!-- by default, use maven 2 source base dir --> + <maven.src.dir>${basedir}/src</maven.src.dir> + + <!-- where to generate sources --> + <maven.gen.dir>${project.build.directory}/generated-sources</maven.gen.dir> + + <!-- where to generate test sources --> + <maven.test.gen.dir>${project.build.directory}/generated-test-sources</maven.test.gen.dir> + + <!-- locales for the site generation, by default only french --> + <maven.site.locales>fr</maven.site.locales> + + <!-- le fichier de license du projet --> + <maven.license.file>${project.basedir}/LICENSE.txt</maven.license.file> + + <!-- to allow bad tests --> + <maven.test.testFailureIgnore>false</maven.test.testFailureIgnore> + + <!-- to skip tests (can use also profile notests) --> + <maven.test.skip>false</maven.test.skip> + + <!-- to control fork mode of tests --> + <maven.test.forkMode>once</maven.test.forkMode> + + <!-- to activate generation of reports and javadoc when doing a site --> + <maven.reports.generate>true</maven.reports.generate> + + <!-- do not use 2.5 version, it is buggy (crazy aggregate mode !) --> + <javadoc.version>2.4</javadoc.version> + + <!-- pour ne pas generer la javadoc (quand on aura un javadoc 2.5) --> + <maven.javadoc.skip>false</maven.javadoc.skip> + + <maven.version>2.0.10</maven.version> + <helper.version>1.0.3-SNAPSHOT</helper.version> + + <!-- default license to use --> + <license.licenseName>lgpl_v3</license.licenseName> + + <!-- release repository url (to be used in site.xml) --> + <repository.home.url>http://maven.${platform}/release</repository.home.url> + + <!-- generated changes.xml file --> + <maven.changeFile>${maven.gen.dir}/changes/changes.xml</maven.changeFile> + + </properties> + <build> + + <defaultGoal>install</defaultGoal> + + <plugins> + + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-helper-plugin</artifactId> + <executions> + <!-- check that the root module has a changelog.txt file --> + <execution> + <id>check-project-files</id> + <goals> + <goal>check-project-files</goal> + </goals> + <configuration> + <verbose>true</verbose> + </configuration> + </execution> + </executions> + </plugin> + + <plugin> + <artifactId>maven-plugin-plugin</artifactId> + <executions> + <execution> + <goals> + <goal>helpmojo</goal> + </goals> + </execution> + </executions> + </plugin> + + </plugins> + + <pluginManagement> + <plugins> + + <plugin> + <artifactId>maven-resources-plugin</artifactId> + <version>2.3</version> + <configuration> + <encoding>${project.build.sourceEncoding}</encoding> + </configuration> + </plugin> + + <plugin> + <artifactId>maven-compiler-plugin</artifactId> + <version>2.0.2</version> + <configuration> + <source>${maven.compile.source}</source> + <target>${maven.compile.target}</target> + <encoding>${project.build.sourceEncoding}</encoding> + </configuration> + </plugin> + + <plugin> + <artifactId>maven-surefire-plugin</artifactId> + <version>2.4.3</version> + <configuration> + <skip>${maven.test.skip}</skip> + <testFailureIgnore>${maven.test.testFailureIgnore}</testFailureIgnore> + <forkMode>${maven.test.forkMode}</forkMode> + </configuration> + </plugin> + + <plugin> + <artifactId>maven-dependency-plugin</artifactId> + <version>2.1</version> + <executions> + <execution> + <id>copy-dependencies</id> + <phase>package</phase> + <goals> + <goal>copy-dependencies</goal> + </goals> + <configuration> + <overWriteReleases>false</overWriteReleases> + <overWriteSnapshots>false</overWriteSnapshots> + <overWriteIfNewer>true</overWriteIfNewer> + <outputDirectory>${project.build.directory}/lib</outputDirectory> + </configuration> + </execution> + </executions> + </plugin> + + <plugin> + <artifactId>maven-war-plugin</artifactId> + <version>2.1-beta-1</version> + <configuration> + <warSourceDirectory>${maven.src.dir}/main/webapp</warSourceDirectory> + </configuration> + </plugin> + + <plugin> + <artifactId>maven-jar-plugin</artifactId> + <version>2.2</version> + <inherited>true</inherited> + + <configuration> + <archive> + <!-- cela fait bugger le chargement des service via + ServiceLoader donc on desactive --> + <!--index>true</index--> + <manifest> + <mainClass>${maven.jar.main.class}</mainClass> + </manifest> + <manifestEntries> + <url>${pom.url}</url> + </manifestEntries> + </archive> + </configuration> + </plugin> + + <plugin> + <artifactId>maven-source-plugin</artifactId> + <version>2.1</version> + <inherited>true</inherited> + <executions> + <execution> + <id>attach-sources</id> + <goals> + <goal>jar</goal> + </goals> + </execution> + </executions> + </plugin> + + <plugin> + <artifactId>maven-javadoc-plugin</artifactId> + <version>${javadoc.version}</version> + <configuration> + <docencoding>${project.reporting.outputEncoding}</docencoding> + <encoding>${project.reporting.outputEncoding}</encoding> + <charset>${project.reporting.outputEncoding}</charset> + <quiet>true</quiet> + <excludePackageNames>${maven.javadoc.excludePackageNames}</excludePackageNames> + <!-- uniquement a partir de javadoc 2.5 --> + <!--skip>${maven.javadoc.skip}</skip--> + </configuration> + <executions> + <execution> + <id>attach-javadocs</id> + <goals> + <goal>jar</goal> + </goals> + </execution> + </executions> + </plugin> + + <plugin> + <artifactId>maven-site-plugin</artifactId> + <version>2.0.1</version> + <configuration> + <inputEncoding>${project.reporting.outputEncoding}</inputEncoding> + <outputEncoding>${project.reporting.outputEncoding}</outputEncoding> + <generateReports>${maven.reports.generate}</generateReports> + <locales>${maven.site.locales}</locales> + </configuration> + </plugin> + + <plugin> + <artifactId>maven-release-plugin</artifactId> + <version>2.0-beta-9</version> + </plugin> + + <plugin> + <artifactId>maven-plugin-plugin</artifactId> + <version>2.5</version> + </plugin> + + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-helper-plugin</artifactId> + <version>${helper.version}</version> + </plugin> + + <plugin> + <artifactId>maven-enforcer-plugin</artifactId> + <version>1.0-beta-1</version> + </plugin> + + </plugins> + </pluginManagement> + + </build> + + <reporting> + <plugins> + <plugin> + <artifactId>maven-plugin-plugin</artifactId> + </plugin> + + <!-- + The Project Info Reports Plugin has twelve goals: + see http://maven.apache.org/plugins/maven-project-info-reports-plugin + --> + <plugin> + <artifactId>maven-project-info-reports-plugin</artifactId> + <version>2.1.2</version> + </plugin> + + <plugin> + <artifactId>maven-javadoc-plugin</artifactId> + <version>${javadoc.version}</version> + <configuration> + <quiet>true</quiet> + <docencoding>${project.build.sourceEncoding}</docencoding> + <encoding>${project.build.sourceEncoding}</encoding> + <excludePackageNames>${maven.javadoc.excludePackageNames}</excludePackageNames> + </configuration> + </plugin> + + <!-- changelog:changelog + changelog:dev-activity + changelog:file-activity --> + <!--FIXME : TC-20090816 : there is a bug with fileactivity + in report, trunk url are prefix with tag/xxx-releaseNumber !--> + <plugin> + <artifactId>maven-changelog-plugin</artifactId> + <version>2.1</version> + <!--configuration> + <displayFileDetailUrl>http://svn.${platform}/svn/${projectId}%FILE%</displayFileDetailUrl> + </configuration--> + </plugin> + + <!-- Implicit add of reportSet to not generate jira reports --> + <plugin> + <artifactId>maven-changes-plugin</artifactId> + <version>2.1</version> + <!--configuration> + <issueLinkTemplate>http://www.${platform}/issues/show/%ISSUE%</issueLinkTemplate> + <xmlPath>${maven.changeFile}</xmlPath> + </configuration--> + <reportSets> + <reportSet> + <reports> + <report>changes-report</report> + </reports> + </reportSet> + </reportSets> + </plugin> + + <plugin> + <artifactId>maven-checkstyle-plugin</artifactId> + <version>2.3</version> + <configuration> + <encoding>${project.reporting.outputEncoding}</encoding> + </configuration> + </plugin> + + <plugin> + <artifactId>maven-pmd-plugin</artifactId> + <version>2.4</version> + <configuration> + <linkXRef>true</linkXRef> + <sourceEncoding>${project.reporting.outputEncoding}</sourceEncoding> + <minimumTokens>100</minimumTokens> + <targetJdk>${maven.compile.target}</targetJdk> + </configuration> + + </plugin> + + <plugin> + <artifactId>maven-jxr-plugin</artifactId> + <version>2.1</version> + </plugin> + + <plugin> + <artifactId>maven-surefire-report-plugin</artifactId> + <version>2.4.3</version> + </plugin> + + <!-- a voir si on le garde car hudson le fait aussi ? --> + <plugin> + <groupId>org.codehaus.mojo</groupId> + <artifactId>cobertura-maven-plugin</artifactId> + <version>2.3</version> + </plugin> + + <!-- a tester si c'est viable sur du multi-module --> + <!-- il y a une version 2.1 voir pour la conf car sans conf ca plante --> + <!--plugin> + <groupId>org.codehaus.mojo</groupId> + <artifactId>findbugs-maven-plugin</artifactId> + <version>1.2</version> + </plugin--> + </plugins> + </reporting> + + <!-- ************************************************************* --> + <!-- *** Build Environment ************************************** --> + <!-- ************************************************************* --> + + <!-- Build Environment : Environment Information --> + + <issueManagement> + <system>redmine</system> + <url>http://www.${platform}/projects/sandbox/issues</url> + </issueManagement> + + <ciManagement> + <system>hudson</system> + <url>http://hudson.${platform}/hudson/job/${projectId}</url> + </ciManagement> + + <!--Any mailing lists for the project--> + <mailingLists> + <mailingList> + <name>${listId}-commits</name> + <subscribe>http://list.${platform}/cgi-bin/mailman/listinfo/${listId}-commits</subscribe> + <unsubscribe>http://list.${platform}/cgi-bin/mailman/listinfo/${listId}-commits</unsubscribe> + <post>${listId}-commits@list.${platform}</post> + <archive>http://list.${platform}/pipermail/${listId}-commits/</archive> + </mailingList> + + <mailingList> + <name>${listId}-devel</name> + <subscribe>http://list.${platform}/cgi-bin/mailman/listinfo/${listId}-devel</subscribe> + <unsubscribe>http://list.${platform}/cgi-bin/mailman/listinfo/${listId}-devel</unsubscribe> + <post>${listId}-devel@list.${platform}</post> + <archive>http://list.${platform}/pipermail/${listId}-devel/</archive> + </mailingList> + + <mailingList> + <name>${listId}-users</name> + <subscribe>http://list.${platform}/cgi-bin/mailman/listinfo/${listId}-users</subscribe> + <unsubscribe>http://list.${platform}/cgi-bin/mailman/listinfo/${listId}-users</unsubscribe> + <post>${listId}-users@list.${platform}</post> + <archive>http://list.${platform}/pipermail/${listId}-users/</archive> + </mailingList> + </mailingLists> + + <!-- Source control management. --> + <scm> + <connection>scm:svn:http://svn.nuiton.org/svn/sandbox/maven-redmine-plugin/trunk</connection> + <developerConnection>scm:svn:http://svn.nuiton.org/svn/sandbox/maven-redmine-plugin/trunk</developerConnection> + <url>http://www.nuiton.org/repositories/browse/sandbox/maven-redmine-plugin/trunk</url> + </scm> + +</project> Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/RedmineSession.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/RedmineSession.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/RedmineSession.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,215 @@ +package org.nuiton.redmine; + +import org.nuiton.redmine.plugin.*; +import java.io.IOException; +import java.net.URISyntaxException; +import java.net.URL; +import java.util.Arrays; + +import org.apache.commons.httpclient.Cookie; +import org.apache.commons.httpclient.HostConfiguration; +import org.apache.commons.httpclient.HttpClient; +import org.apache.commons.httpclient.HttpConnection; +import org.apache.commons.httpclient.HttpMethod; +import org.apache.commons.httpclient.HttpState; +import org.apache.commons.httpclient.HttpStatus; +import org.apache.commons.httpclient.StatusLine; +import org.apache.commons.httpclient.methods.PostMethod; +import org.apache.maven.plugin.logging.Log; + +/** + * To store a redmine session and exeuctes some requests on redmine. + * <p/> + * To obtain a session, use the static factory method {@link #getSession(org.apache.maven.plugin.logging.Log, java.net.URL, String, String, boolean)}. + * + * The method {@link #askData(String[])} retreave some data from redmine, + * once logged in. + * <p/> + * The method {@link #sendData(String[])} send some data to redmine, + * once logged in. + * <p/> + * The method {@link #logout()} close the session to redmine. After this method + * + * @author chemit + * @since 1.0.0 + */ +public class RedmineSession { + + protected HttpClient client; + protected Log log; + protected boolean login; + protected boolean showRequest; + + public static RedmineSession getSession(Log log, URL url, String username, String password, boolean showRequest) throws IOException, URISyntaxException { + + RedmineSession session = new RedmineSession(log, url, showRequest); + + // ask rest/ping service a ping + + try { + String content = session.askContent(new String[]{"rest", "ping"}); + + boolean ok = "ping".equals(content); + if (!ok) { + throw new IOException("can not connect to " + url); + } + } catch (IOException ex) { + throw ex; + } catch (DataNotFoundException ex) { + // should never happeds + log.error(ex.getMessage()); + } + + // ask rest/login a connection + + String uri = session.getUri("rest", "login"); + + HttpMethod gm = session.doRequest(uri, "username", username, "password", password); + + StatusLine sl = gm.getStatusLine(); + int statusCode = sl.getStatusCode(); + if (log.isDebugEnabled()) { + log.debug("status code " + statusCode + " for " + gm.getPath()); + } + + if (statusCode != HttpStatus.SC_OK) { + gm.releaseConnection(); + throw new IOException("Got error code <" + statusCode + ":" + sl.getReasonPhrase() + "> on " + gm.getPath()); + } + + // ok session is logged in + + session.login = true; + + return session; + } + + protected RedmineSession(Log log, URL uri, boolean showRequest) { + this.showRequest = showRequest; + this.log = log; + this.client = new HttpClient(); + HostConfiguration hostConfiguration = new HostConfiguration(); + hostConfiguration.setHost(uri.getHost()); + this.client.setHostConfiguration(hostConfiguration); + this.client.setState(new HttpState()); + } + + public boolean isLogin() { + return login; + } + + public String askData(String[] paths, String... params) throws IOException, DataNotFoundException { + + String uri = getUri(paths); + HttpMethod gm = doRequest(uri, params); + + StatusLine sl = gm.getStatusLine(); + int statusCode = sl.getStatusCode(); + + if (log.isDebugEnabled()) { + log.debug("status code " + statusCode + " for " + gm.getPath()); + } + String content = gm.getResponseBodyAsString(); + + if (statusCode == HttpStatus.SC_NOT_FOUND) { + throw new DataNotFoundException("could not retreave some datas : " + content); + } + if (statusCode != HttpStatus.SC_OK) { + log.error(content); + releaseConnection(getConnection()); + throw new IOException("Got error code <" + statusCode + ":" + sl.getReasonPhrase() + "> on " + gm.getPath()); + } + return content; + } + + public String sendData(String[] paths, String... params) throws IOException, DataNotFoundException { + + String uri = getUri(paths); + HttpMethod gm = doRequest(uri, params); + + StatusLine sl = gm.getStatusLine(); + int statusCode = sl.getStatusCode(); + + if (log.isDebugEnabled()) { + log.debug("status code " + statusCode + " for " + gm.getPath()); + } + String content = gm.getResponseBodyAsString(); + + if (statusCode != HttpStatus.SC_OK) { + log.error(content); + releaseConnection(getConnection()); + throw new IOException("Got error code <" + statusCode + ":" + sl.getReasonPhrase() + "> on " + gm.getPath()); + } + return content; + } + + public String askContent(String... paths) throws IOException, DataNotFoundException { + + String content = askData(paths, new String[0]); + + return content; + } + + public void logout() throws IOException { + + String uri = getUri("rest", "logout"); + doRequest(uri); + client.getState().clearCookies(); + releaseConnection(getConnection()); + this.login = false; + } + + protected void releaseConnection(HttpConnection connection) { + if (connection != null && connection.isOpen()) { + client.getHttpConnectionManager().releaseConnection(connection); + } + } + + protected HttpConnection getConnection() { + return client.getHttpConnectionManager().getConnection(client.getHostConfiguration()); + } + + protected String getUri(String... paths) { + String uri = client.getHostConfiguration().getHostURL(); + for (String path : paths) { + uri += '/' + path; + } + return uri; + } + + protected HttpMethod doRequest(String uri, String... parameters) throws IOException { + if (showRequest) { + log.info("doRequest " + uri); + } + if (log.isDebugEnabled()) { + log.debug("doRequest with parameters : " + Arrays.toString(parameters)); + } + PostMethod gm = new PostMethod(uri); + + if (parameters.length > 0) { + + // add parameters + + int nbParams = parameters.length / 2; + for (int i = 0; i < nbParams; i++) { + String key = parameters[2 * i]; + String value = parameters[2 * i + 1]; + gm.addParameter(key, value); + } + } + + if (login) { + Cookie[] cookies = client.getState().getCookies(); + for (Cookie c : cookies) { + if (log.isDebugEnabled()) { + log.debug("push cookie : " + c.getName() + "=" + c.getValue()); + } + gm.addRequestHeader("Cookie", c.toExternalForm()); + } + } + + client.executeMethod(gm); + + return gm; + } +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/RedmineSession.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Issue.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Issue.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Issue.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,13 @@ +package org.nuiton.redmine.model; + +/** + * + * @author chemit + * @since 1.0.0 + */ +public class Issue { + + protected String id; + protected String description; + protected String status; +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Issue.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Project.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Project.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Project.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,16 @@ +package org.nuiton.redmine.model; + +/** + * redmine project + * + * @author chemit + * @since 1.0.0 + */ +public class Project { + + protected String id; + protected String label; + protected String description; + + +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Project.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Tracker.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Tracker.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Tracker.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,11 @@ +package org.nuiton.redmine.model; + +/** + * + * @author chemit + * @since 1.0.0 + */ +public class Tracker { + + protected String type; +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Tracker.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/User.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/User.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/User.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,13 @@ +package org.nuiton.redmine.model; + +/** + * + * @author chemit + * + * @since 1.0.0 + */ +public class User { + + protected String id; + protected String email; +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/User.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Version.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Version.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Version.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,11 @@ +package org.nuiton.redmine.model; + +/** + * + * @author chemit + * @since 1.0.0 + */ +public class Version { + + protected String version; +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/model/Version.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/AbstractGetProjectDataMojo.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/AbstractGetProjectDataMojo.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/AbstractGetProjectDataMojo.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,79 @@ +package org.nuiton.redmine.plugin; + +import java.util.Arrays; +import org.apache.maven.plugin.MojoFailureException; + +/** + * Abstract goal to retreave some datas on a project. + * + * @author tchemit + * @since 1.0.0 + */ +public abstract class AbstractGetProjectDataMojo extends AbstractRedmineMojo { + + public static interface DataType { + + String getAction(); + } + + public enum DataFormat { + + json, + xml + } + /** + * Project identifier. + * + * @parameter expression="${projectId}" + * @required + * @since 1.0.0 + */ + protected String projectId; + /** + * The data format to retreave (all values of enum {@link #DataFormat}) : + * <ul> + * <li>json</li> + * <li>xml</li> + * </ul> + * <p/> + * <p/> + * + * @parameter expression="${redmine.dataFormat}" default-value="xml" + * @required + * @since 1.0.0 + */ + protected String dataFormat; + /** + * The action to be send to redmine, will be compute in + * {@link #init()} method. + */ + protected String action; + + protected abstract DataType getDataType() throws MojoFailureException; + + @Override + protected boolean init() throws Exception { + + action = buildAction(); + + return super.init(); + } + + protected String buildAction() throws MojoFailureException { + + DataType _dataType = getDataType(); + + DataFormat _dataFormat = getDataFormat(); + + return _dataType.getAction() + "." + _dataFormat.name(); + } + + protected DataFormat getDataFormat() throws MojoFailureException { + try { + DataFormat _dataFormat = DataFormat.valueOf(dataFormat); + return _dataFormat; + } catch (Exception e) { + throw new MojoFailureException("could not obtain data format " + dataFormat + " in " + Arrays.toString(DataFormat.values())); + } + } +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/AbstractGetProjectDataMojo.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/AbstractRedmineMojo.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/AbstractRedmineMojo.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/AbstractRedmineMojo.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,231 @@ +/** + * Copyright 2008 fastConnect. + * + * This file is part of maven-redmine-plugin Mojo. + * + * This is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This software is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this software. If not, see <http://www.gnu.org/licenses/>. + */ +package org.nuiton.redmine.plugin; + +import org.nuiton.redmine.RedmineSession; +import java.io.IOException; +import java.net.URL; + +import org.apache.maven.model.IssueManagement; +import org.apache.maven.plugin.MojoExecutionException; +import org.apache.maven.plugin.MojoFailureException; +import org.apache.maven.project.MavenProject; +import org.apache.maven.settings.Server; +import org.apache.maven.settings.Settings; +import org.nuiton.AbstractPlugin; +import org.sonatype.plexus.components.sec.dispatcher.SecDispatcher; +import org.sonatype.plexus.components.sec.dispatcher.SecDispatcherException; + +/** + * Provides basic methods to interact with Redmine. + */ +public abstract class AbstractRedmineMojo extends AbstractPlugin { + + /** + * Dependance du projet. + * + * @parameter default-value="${project}" + * @required + * @readonly + * @since 1.0.0 + */ + protected MavenProject project; + /** + * Dependance du settings. + * + * @parameter default-value="${settings}" + * @required + * @readonly + * @since 1.0.0 + */ + protected Settings settings; + /** + * Configuration of issue management. + * <p/> + * If no redmineUrl defined, will use the issue management to guess the + * redmine url. + * + * @parameter default-value="${project.issueManagement}" + * @readonly + * @since 1.0.0 + */ + protected IssueManagement issueManagement; + /** + * Server id to use for authentication (must be defined in your setting + * and use the maven >= 2.1.0 password encryption mecanism). + * <p/> + * + * @parameter expression="${redmine.serverId}" + * @required + * @since 1.0.0 + */ + protected String serverId; + /** + * The real basedir redmine url. + * + * @parameter expression="${redmine.url}" + * @since 1.0.0 + */ + protected URL redmineUrl; + /** + * The redmine's server login. + * + * @parameter expression="${redmine.username}" + * @since 1.0.0 + */ + protected String redmineUsername; + /** + * The redmine's server password. + * + * @parameter expression="${redmine.password}" + * @since 1.0.0 + */ + protected String redminePassword; + /** + * Un flag pour activer le mode verbeux. + * + * @parameter expression="${redmine.verbose}" default-value="${maven.verbose}" + * @since 1.0.0 + */ + protected boolean verbose; + /** + * password decypher + * @component + * @since 1.0.0 + */ + protected SecDispatcher sec; + /** + * redmine session + * @since 1.0.0 + */ + protected RedmineSession session; + + public AbstractRedmineMojo() { + super("skip message"); + } + + @Override + protected boolean ensurePackaging() { + // accept all packages + return false; + } + + @Override + protected boolean init() throws Exception { + + if (redmineUrl == null || redmineUrl.toString().isEmpty()) { + + // no redmine url specified, guess it from issueManagement + + String system = issueManagement.getSystem(); + if (!"redmine".equals(system)) { + throw new MojoExecutionException("must use a redmine issueManagment system, but found : " + system); + } + String url = issueManagement.getUrl(); + redmineUrl = new URL(url); + } + + if (getLog().isDebugEnabled()) { + getLog().debug("redmine url " + redmineUrl); + } + + if (redmineUsername == null || redmineUsername.trim().isEmpty() || redminePassword == null || redminePassword.trim().isEmpty()) { + + // guess login and password from server in settings + + Server server = settings.getServer(serverId); + if (server == null) { + throw new MojoFailureException("could not find serverId " + serverId); + } + redmineUsername = server.getUsername(); + redminePassword = server.getPassword(); + try { + redminePassword = sec.decrypt(redminePassword); + } catch (SecDispatcherException ex) { + throw new MojoFailureException("could not decrypt password", ex); + } + } + + try { + + session = RedmineSession.getSession(getLog(), redmineUrl, redmineUsername, redminePassword, verbose); + + } catch (IOException e) { + throw new MojoExecutionException("Unable to login to <" + redmineUrl + "> with user <" + redmineUsername + ">", e); + } + + // auth to redmine is ok + + getLog().info("authentication to " + redmineUrl + " done for " + redmineUsername); + + return true; + } + + public String getServerId() { + return serverId; + } + + public void setServerId(String serverId) { + this.serverId = serverId; + } + + public IssueManagement getIssueManagement() { + return issueManagement; + } + + public void setIssueManagement(IssueManagement issueManagement) { + this.issueManagement = issueManagement; + } + + public URL getRedmineUrl() { + return redmineUrl; + } + + public void setRedmineUrl(URL redmineUrl) { + this.redmineUrl = redmineUrl; + } + + public Settings getSettings() { + return settings; + } + + public void setSettings(Settings settings) { + this.settings = settings; + } + + @Override + public boolean isVerbose() { + return verbose; + } + + @Override + public void setVerbose(boolean verbose) { + this.verbose = verbose; + } + + @Override + public MavenProject getProject() { + return project; + } + + @Override + public void setProject(MavenProject project) { + this.project = project; + } +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/AbstractRedmineMojo.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/DataNotFoundException.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/DataNotFoundException.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/DataNotFoundException.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,27 @@ +package org.nuiton.redmine.plugin; + +/** + * An exception to throw when a data does not exists on redmine. + * + * @author chemit + * @since 1.0.0 + */ +public class DataNotFoundException extends Exception { + + private static final long serialVersionUID = 1L; + + public DataNotFoundException(Throwable cause) { + super(cause); + } + + public DataNotFoundException(String message, Throwable cause) { + super(message, cause); + } + + public DataNotFoundException(String message) { + super(message); + } + + public DataNotFoundException() { + } +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/DataNotFoundException.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GenerateChangesMojo.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GenerateChangesMojo.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GenerateChangesMojo.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,18 @@ +package org.nuiton.redmine.plugin; + +/** + * Generates the changes.xml file from the Redmine's server + * + * @author tchemit + * @goal generate-changes + * @requiresProject true + * + * @since 1.0.0 + */ +public class GenerateChangesMojo extends AbstractRedmineMojo { + + @Override + protected void doAction() throws Exception { + //TODO-FILL_ME + } +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GenerateChangesMojo.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GetProjectDataMojo.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GetProjectDataMojo.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GetProjectDataMojo.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,71 @@ +package org.nuiton.redmine.plugin; + +import java.util.Arrays; +import org.apache.maven.plugin.MojoFailureException; + +/** + * Retreave some datas on a project. + * + * Given the {@link #dataType}, the {link #dataFormat} and the + * {@link #projectId}, will ask to redmine server, all datas required. + * + * @author tchemit + * @goal retreave-project-data + * @requiresProject true + * + * @since 1.0.0 + */ +public class GetProjectDataMojo extends AbstractGetProjectDataMojo { + + /** + * The data type to retreave (all values of enum {@link #DataType} : + * <ul> + * <li>project</li> + * <li>users</li> + * <li>trackers</li> + * <li>versions</li> + * </ul> + * <p/> + * + * @parameter expression="${redmine.projectDataType}" + * @required + * @since 1.0.0 + */ + protected String dataType; + + @Override + protected DataType getDataType() throws MojoFailureException { + VersionDataType _dataType; + try { + _dataType = VersionDataType.valueOf(dataType); + } catch (Exception e) { + throw new MojoFailureException("could not obtain data type " + dataType + " in " + Arrays.toString(VersionDataType.values())); + } + return _dataType; + } + + @Override + protected void doAction() throws Exception { + + String result = session.askContent("rest", action, projectId); + getLog().info(result); + } + + public enum VersionDataType implements DataType { + + project("get_project"), + users("get_project_users"), + trackers("get_project_trackers"), + versions("get_project_versions"); + final String action; + + private VersionDataType(String action) { + this.action = action; + } + + @Override + public String getAction() { + return action; + } + } +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GetProjectDataMojo.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GetProjectVersionDataMojo.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GetProjectVersionDataMojo.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GetProjectVersionDataMojo.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,79 @@ +package org.nuiton.redmine.plugin; + +import java.util.Arrays; +import org.apache.maven.plugin.MojoFailureException; + +/** + * Retreave some datas on a project. + * + * Given the {@link #dataType}, the {link #dataFormat} and the + * {@link #projectId}, and {@link #versionId} will ask to redmine server, + * all datas required. + * + * @author tchemit + * @goal get-project-version-data + * @requiresProject true + * + * @since 1.0.0 + */ +public class GetProjectVersionDataMojo extends AbstractGetProjectDataMojo { + + /** + * Version identifier. + * + * @parameter expression="${versionId}" + * @required + * @since 1.0.0 + */ + protected String versionId; + /** + * The data type to retreave (all values of enum {@link #DataType} : + * <ul> + * <li>version</li> + * <li>issues</li> + * <li>files</li> + * </ul> + * <p/> + * + * @parameter expression="${redmine.versionDataType}" + * @required + * @since 1.0.0 + */ + protected String dataType; + + @Override + protected void doAction() throws Exception { + + String result = session.askData(new String[]{"rest", action, projectId}, "version_name", versionId); + + getLog().info(result); + } + + @Override + protected DataType getDataType() throws MojoFailureException { + VersionDataType _dataType; + try { + _dataType = VersionDataType.valueOf(dataType); + } catch (Exception e) { + throw new MojoFailureException("could not obtain data type " + dataType + " in " + Arrays.toString(VersionDataType.values())); + } + return _dataType; + } + + public enum VersionDataType implements DataType { + + version("get_version"), + issues("get_version_issues"), + files("get_version_files"); + final String action; + + private VersionDataType(String action) { + this.action = action; + } + + @Override + public String getAction() { + return action; + } + } +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/GetProjectVersionDataMojo.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/RedmineReportMojo.java =================================================================== --- maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/RedmineReportMojo.java (rev 0) +++ maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/RedmineReportMojo.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,19 @@ +package org.nuiton.redmine.plugin; + +/** + * Generates a report for issues from Redmine's server + * + * @author tchemit + * @goal redmine-report + * @requiresProject true + * @requiresDirectInvocation + * + * @since 1.0.0 + */ +public class RedmineReportMojo extends AbstractRedmineMojo { + + @Override + protected void doAction() throws Exception { + //TODO-FILL_ME + } +} Property changes on: maven-redmine-plugin/trunk/src/main/java/org/nuiton/redmine/plugin/RedmineReportMojo.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/site/apt/Todo.apt =================================================================== --- maven-redmine-plugin/trunk/src/site/apt/Todo.apt (rev 0) +++ maven-redmine-plugin/trunk/src/site/apt/Todo.apt 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,8 @@ +---- +TODO +---- +---- +2009-0906 +---- + +Any idea ? Added: maven-redmine-plugin/trunk/src/site/apt/index.apt =================================================================== --- maven-redmine-plugin/trunk/src/site/apt/index.apt (rev 0) +++ maven-redmine-plugin/trunk/src/site/apt/index.apt 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,32 @@ +---- +Introduction +---- +---- +2009-09-06 +---- + +maven-redmine-plugin + + //TODO-FILL_ME + + +* Presentation + + //TODO-FILL_ME + +* Goals Overview + + The plugin has the following goals: + + //TODO-FILL_ME + + + * {{{help-mojo.html}help}} display help about the plugin (goals, usage). + +* Usage + + Instructions on how to use the Plugin can be found on {{{usage.html}usage}} page + +* Examples + + to be done. Added: maven-redmine-plugin/trunk/src/site/apt/usage.apt =================================================================== --- maven-redmine-plugin/trunk/src/site/apt/usage.apt (rev 0) +++ maven-redmine-plugin/trunk/src/site/apt/usage.apt 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,37 @@ +---- +Usage +---- +---- +2009-09-06 +---- + +generate-changes goal + +------------------------------------------------------------------------------ + + //TODO-FILL_ME +------------------------------------------------------------------------------ + +* How does it work ? + + //TODO-FILL_ME + + +help goal + + This goal display the help of the plugin (available goals). + + Use it directly (and only) from commandline : + +------------------------------------------------------------------------------ + + mvn license:help +------------------------------------------------------------------------------ + + To display verbose help : + +------------------------------------------------------------------------------ + mvn license:help -Ddetail +------------------------------------------------------------------------------ + + for full detail see {{{help-mojo.html}help}} detail page. Added: maven-redmine-plugin/trunk/src/site/site.xml =================================================================== --- maven-redmine-plugin/trunk/src/site/site.xml (rev 0) +++ maven-redmine-plugin/trunk/src/site/site.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,52 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project name="${project.name}"> + + <publishDate format="dd/MM/yyyy"/> + + <skin> + <groupId>org.nuiton</groupId> + <artifactId>maven-nuiton-skin</artifactId> + <version>1.0.0</version> + </skin> + <bannerLeft> + <name>${project.name}</name> + <href>index.html</href> + </bannerLeft> + + <bannerRight> + <src>http://www.codelutin.com/images/lutinorange-codelutin.png</src> + <href>${project.organization.url}</href> + </bannerRight> + + <poweredBy> + <logo href="http://maven.apache.org" name="Maven" img="images/logos/maven-feather.png"/> + </poweredBy> + + <body> + + <breadcrumbs> + <item name="${project.name}" href="${project.url}" /> + </breadcrumbs> + + <menu name="Utilisateur"> + <item name="Introduction" href="index.html"/> + <item name="Usage" href="usage.html"/> + <item name="Goals" href="plugin-info.html"> + <item name="${mojoGoal}" href="${mojoGoal}-mojo.html"/> + <item name="help" href="help-mojo.html"/> + </item> + </menu> + + <menu name="Téléchargement"> + <item href="${repository.home.url}/org/nuiton/maven-redmine-plugin/${project.version}/${project.build.finalName}.jar" + name="Librairie (jar)"/> + <item href="${repository.home.url}/org/nuiton/maven-redmine-plugin/${project.version}/${project.build.finalName}-javadoc.jar" + name="Javadoc (jar)"/> + <item href="${repository.home.url}/org/nuiton/maven-redmine-plugin/${project.version}/${project.build.finalName}-sources.jar" + name="Sources (jar)"/> + </menu> + + <menu ref="reports"/> + + </body> +</project> Added: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/RedmineSessionTest.java =================================================================== --- maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/RedmineSessionTest.java (rev 0) +++ maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/RedmineSessionTest.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,122 @@ +package org.nuiton.redmine; + +import java.io.IOException; +import java.net.URISyntaxException; +import java.net.URL; +import org.apache.maven.plugin.logging.SystemStreamLog; +import org.junit.After; +import org.junit.AfterClass; +import org.junit.Assert; +import org.junit.Assume; +import org.junit.Before; +import org.junit.BeforeClass; +import org.junit.Test; + +/** + * + * @author chemit + */ +public class RedmineSessionTest { + + protected static SystemStreamLog log; + protected static URL redmineURL; + protected static final String redmineUsername = "chemit"; + protected static final String redminePassword = "azer"; + protected static Boolean skip; + protected RedmineSession session; + + /** + * Test si on peut se connecter a un serveur Redmine. + * + * @param redmineURL l'url du serveur redmine + * @param redmineUsername le login + * @param redminePassword le password + * @return <code>true</true> si une connection est possible sur le serveur + */ + public static boolean canAccess(URL redmineURL, String redmineUsername, String redminePassword) { + log = new SystemStreamLog(); + boolean result = false; + try { + RedmineSession.getSession(log, redmineURL, redmineUsername, redminePassword, true); + result = true; + } catch (Exception e) { + log.warn("can not connect to " + redmineURL + ", test will be skip : " + e.getMessage()); + } + return result; + } + + @BeforeClass + public static void setUpClass() throws Exception { + log = new SystemStreamLog(); + redmineURL = new URL("http://www.mynuiton.org"); + skip = !canAccess(redmineURL, redmineUsername, redminePassword); + } + + @AfterClass + public static void tearDownClass() throws Exception { + } + + @Before + public void setUp() { + Assume.assumeTrue(!skip); + } + + @After + public void tearDown() throws IOException { + if (session != null && session.isLogin()) { + session.logout(); + session = null; + } + } + + @Test(expected = IOException.class) + public void testBadHost() throws Exception { + + RedmineSession.getSession(log, new URL("http://www.mynuiton.orgfake-" + System.nanoTime()), null, null, true); + } + + @Test(expected = IOException.class) + public void testBadLogin() throws Exception { + session = RedmineSession.getSession(log, redmineURL, redmineUsername + System.nanoTime(), redminePassword, true); + } + + @Test + public void testLogin() throws Exception { + initSession(); + session.logout(); + } + + @Test + public void testAskData() throws Exception { + initSession(); + String result = session.askContent("rest", "get_project_users.xml", "one"); + Assert.assertFalse(result.isEmpty()); + if (log.isDebugEnabled()) { + log.debug(result); + } + session.logout(); + Assert.assertFalse(session.isLogin()); + } + + @Test + public void testAskDataAfterClosed() throws Exception { + initSession(); + String result = session.askContent("rest", "get_project_users.xml", "one"); + Assert.assertFalse(result.isEmpty()); + if (log.isDebugEnabled()) { + log.debug(result); + } + session.logout(); + Assert.assertFalse(session.isLogin()); + try { + result = session.askContent("rest", "get_project_users.json", "one"); + Assert.fail(); + } catch (IOException e) { + Assert.assertTrue(true); + } + } + + protected void initSession() throws IOException, URISyntaxException { + session = RedmineSession.getSession(log, redmineURL, redmineUsername, redminePassword, true); + } +} Property changes on: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/RedmineSessionTest.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/AbstractRedmineMojoTest.java =================================================================== --- maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/AbstractRedmineMojoTest.java (rev 0) +++ maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/AbstractRedmineMojoTest.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,53 @@ +package org.nuiton.redmine.plugin; + +import org.apache.maven.plugin.MojoExecutionException; +import org.apache.maven.plugin.MojoFailureException; +import org.apache.maven.plugin.logging.Log; +import org.junit.AfterClass; +import org.junit.Assert; +import org.junit.Assume; +import org.junit.Before; +import org.nuiton.util.BasePluginTestCase; + +/** + * @param <P> the goal to test + * @author tchemit + * @since 1.0.0 + */ +public abstract class AbstractRedmineMojoTest<P extends AbstractRedmineMojo> extends BasePluginTestCase<P> { + + protected static Log log; + + @AfterClass + public static void cleanAfterClass() throws Exception { + if (log != null) { + log.info("release test " + testDir.getName()); + log = null; + } + configItr = null; + testDir = null; + } + + @Before + @Override + public void setUp() throws Exception { + super.setUp(); + Assert.assertNotNull(mojo); + boolean canContinue = false; + try { + if (mojo.init()) { + canContinue = true; + } + mojo.getLog().info("setup done for " + mojo.getProject().getFile().getName()); + } catch (MojoFailureException ex) { + mojo.getLog().warn("can not init mojo" + mojo.getProject().getFile().getName() + ", test will be skip : " + ex.getMessage()); + throw ex; + } catch (MojoExecutionException ex) { + mojo.getLog().warn("can not connect to " + mojo.getRedmineUrl() + ", test will be skip : " + ex.getMessage()); + } + if (log == null) { + log = mojo.getLog(); + } + Assume.assumeTrue(canContinue); + } +} Property changes on: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/AbstractRedmineMojoTest.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GenerateChangesMojoTest.java =================================================================== --- maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GenerateChangesMojoTest.java (rev 0) +++ maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GenerateChangesMojoTest.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,26 @@ +package org.nuiton.redmine.plugin; + +import org.nuiton.util.PluginConfig; +import org.junit.BeforeClass; +import org.junit.Test; + +/** + * @author tchemit + * @since 1.0.0 + */ +public class GenerateChangesMojoTest extends AbstractRedmineMojoTest<GenerateChangesMojo> { + + @BeforeClass + public static void initClass() throws Exception { + + initConfigs(GenerateChangesMojoTest.class); + } + + @Test + @PluginConfig(pomName = "generate-changes.xml", goalName = "generate-changes") + public void testGenerateChangesMojo() throws Exception { + + mojo.doAction(); + //TODO check file is generated + } +} Property changes on: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GenerateChangesMojoTest.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GetProjectDataMojoTest.java =================================================================== --- maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GetProjectDataMojoTest.java (rev 0) +++ maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GetProjectDataMojoTest.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,50 @@ +package org.nuiton.redmine.plugin; + +import org.nuiton.util.PluginConfig; +import org.junit.BeforeClass; +import org.junit.Test; + +/** + * @author tchemit + * @since 1.0.0 + */ +public class GetProjectDataMojoTest extends AbstractRedmineMojoTest<GetProjectDataMojo> { + + @BeforeClass + public static void initClass() throws Exception { + + initConfigs(GetProjectDataMojoTest.class); + } + + @Test + @PluginConfig(pomName = "get-project.xml", goalName = "retreave-project-data") + public void testProject() throws Exception { + + mojo.doAction(); + //TODO check file is generated + } + + @Test + @PluginConfig(pomName = "get-project-users.xml", goalName = "retreave-project-data") + public void testUsers() throws Exception { + + mojo.doAction(); + //TODO check file is generated + } + + @Test + @PluginConfig(pomName = "get-project-trackers.xml", goalName = "retreave-project-data") + public void testTrakers() throws Exception { + + mojo.doAction(); + //TODO check file is generated + } + + @Test + @PluginConfig(pomName = "get-project-versions.xml", goalName = "retreave-project-data") + public void testVersions() throws Exception { + + mojo.doAction(); + //TODO check file is generated + } +} Property changes on: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GetProjectDataMojoTest.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest.java =================================================================== --- maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest.java (rev 0) +++ maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,42 @@ +package org.nuiton.redmine.plugin; + +import org.nuiton.util.PluginConfig; +import org.junit.BeforeClass; +import org.junit.Test; + +/** + * @author tchemit + * @since 1.0.0 + */ +public class GetProjectVersionDataMojoTest extends AbstractRedmineMojoTest<GetProjectVersionDataMojo> { + + @BeforeClass + public static void initClass() throws Exception { + + initConfigs(GetProjectVersionDataMojoTest.class); + } + + @Test + @PluginConfig(pomName = "get-version.xml", goalName = "get-project-version-data") + public void testVersion() throws Exception { + + mojo.doAction(); + //TODO check file is generated + } + + @Test + @PluginConfig(pomName = "get-version-issues.xml", goalName = "get-project-version-data") + public void testIssues() throws Exception { + + mojo.doAction(); + //TODO check file is generated + } + + @Test + @PluginConfig(pomName = "get-version-files.xml", goalName = "get-project-version-data") + public void testFiles() throws Exception { + + mojo.doAction(); + //TODO check file is generated + } +} Property changes on: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/RedmineReportMojoTest.java =================================================================== --- maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/RedmineReportMojoTest.java (rev 0) +++ maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/RedmineReportMojoTest.java 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,42 @@ +package org.nuiton.redmine.plugin; + +import org.nuiton.util.PluginConfig; +import org.junit.BeforeClass; +import org.junit.Test; + + +/** + * @author tchemit + * @since 1.0.0 + */ +public class RedmineReportMojoTest extends AbstractRedmineMojoTest<RedmineReportMojo> { + + @BeforeClass + public static void initClass() throws Exception { + initConfigs(RedmineReportMojoTest.class); +// initConfigs(RedmineReportMojoTest.class, "testRedmineReportMojo"); + } + +// @AfterClass +// public static void afterClass() throws Exception { +// configItr = null; +// testDir = null; +// } +// @Before +// @Override +// public void setUp() throws Exception { +// super.setUp(); +// assertNotNull(mojo); +// mojo = (RedmineReportMojo) mojo; +// } +// @Test +// public void testDummy() { +// +// } + @Test + @PluginConfig(pomName = "redmine-report.xml", goalName = "redmine-report") + public void testRedmineReportMojo() throws Exception { + + mojo.doAction(); + } +} Property changes on: maven-redmine-plugin/trunk/src/test/java/org/nuiton/redmine/plugin/RedmineReportMojoTest.java ___________________________________________________________________ Added: svn:keywords + "Author Date Id Revision HeadURL Added: maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GenerateChangesMojoTest/generate-changes.xml =================================================================== --- maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GenerateChangesMojoTest/generate-changes.xml (rev 0) +++ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GenerateChangesMojoTest/generate-changes.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,33 @@ +<?xml version="1.0" encoding="UTF-8"?> +<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"> + + <groupId>org.nuiton.maven-redmine-plugin</groupId> + <artifactId>test-generate-changes</artifactId> + <version>0</version> + + <name>generate-changes</name> + + <build> + + <plugins> + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-redmine-plugin</artifactId> + <configuration> + <redmineUrl>http://mynuiton.org</redmineUrl> + <redmineUsername>chemit</redmineUsername> + <redminePassword>azer</redminePassword> + </configuration> + <executions> + <execution> + <goals> + <goal>generate-changes</goal> + </goals> + </execution> + </executions> + </plugin> + </plugins> + </build> +</project> \ No newline at end of file Added: maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-trackers.xml =================================================================== --- maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-trackers.xml (rev 0) +++ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-trackers.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,37 @@ +<?xml version="1.0" encoding="UTF-8"?> +<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"> + + <groupId>org.nuiton.maven-redmine-plugin</groupId> + <artifactId>test-generate-changes</artifactId> + <version>0</version> + + <name>generate-changes</name> + + <build> + + <plugins> + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-redmine-plugin</artifactId> + <configuration> + <redmineUrl>http://mynuiton.org</redmineUrl> + <redmineUsername>chemit</redmineUsername> + <redminePassword>azer</redminePassword> + <projectId>one</projectId> + <dataType>trackers</dataType> + <dataFormat>xml</dataFormat> + <verbose>true</verbose> + </configuration> + <executions> + <execution> + <goals> + <goal>retreave-project-data</goal> + </goals> + </execution> + </executions> + </plugin> + </plugins> + </build> +</project> \ No newline at end of file Added: maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-users.xml =================================================================== --- maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-users.xml (rev 0) +++ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-users.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,37 @@ +<?xml version="1.0" encoding="UTF-8"?> +<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"> + + <groupId>org.nuiton.maven-redmine-plugin</groupId> + <artifactId>test-generate-changes</artifactId> + <version>0</version> + + <name>generate-changes</name> + + <build> + + <plugins> + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-redmine-plugin</artifactId> + <configuration> + <redmineUrl>http://mynuiton.org</redmineUrl> + <redmineUsername>chemit</redmineUsername> + <redminePassword>azer</redminePassword> + <projectId>one</projectId> + <dataType>users</dataType> + <dataFormat>xml</dataFormat> + <verbose>true</verbose> + </configuration> + <executions> + <execution> + <goals> + <goal>retreave-project-data</goal> + </goals> + </execution> + </executions> + </plugin> + </plugins> + </build> +</project> \ No newline at end of file Added: maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-versions.xml =================================================================== --- maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-versions.xml (rev 0) +++ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project-versions.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,37 @@ +<?xml version="1.0" encoding="UTF-8"?> +<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"> + + <groupId>org.nuiton.maven-redmine-plugin</groupId> + <artifactId>test-generate-changes</artifactId> + <version>0</version> + + <name>generate-changes</name> + + <build> + + <plugins> + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-redmine-plugin</artifactId> + <configuration> + <redmineUrl>http://mynuiton.org</redmineUrl> + <redmineUsername>chemit</redmineUsername> + <redminePassword>azer</redminePassword> + <projectId>one</projectId> + <dataType>versions</dataType> + <dataFormat>xml</dataFormat> + <verbose>true</verbose> + </configuration> + <executions> + <execution> + <goals> + <goal>retreave-project-data</goal> + </goals> + </execution> + </executions> + </plugin> + </plugins> + </build> +</project> \ No newline at end of file Added: maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project.xml =================================================================== --- maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project.xml (rev 0) +++ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectDataMojoTest/get-project.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,37 @@ +<?xml version="1.0" encoding="UTF-8"?> +<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"> + + <groupId>org.nuiton.maven-redmine-plugin</groupId> + <artifactId>test-generate-changes</artifactId> + <version>0</version> + + <name>generate-changes</name> + + <build> + + <plugins> + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-redmine-plugin</artifactId> + <configuration> + <redmineUrl>http://mynuiton.org</redmineUrl> + <redmineUsername>chemit</redmineUsername> + <redminePassword>azer</redminePassword> + <projectId>one</projectId> + <dataType>project</dataType> + <dataFormat>xml</dataFormat> + <verbose>true</verbose> + </configuration> + <executions> + <execution> + <goals> + <goal>retreave-project-data</goal> + </goals> + </execution> + </executions> + </plugin> + </plugins> + </build> +</project> \ No newline at end of file Added: maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version-files.xml =================================================================== --- maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version-files.xml (rev 0) +++ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version-files.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,38 @@ +<?xml version="1.0" encoding="UTF-8"?> +<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"> + + <groupId>org.nuiton.maven-redmine-plugin</groupId> + <artifactId>test-generate-changes</artifactId> + <version>0</version> + + <name>generate-changes</name> + + <build> + + <plugins> + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-redmine-plugin</artifactId> + <configuration> + <redmineUrl>http://mynuiton.org</redmineUrl> + <redmineUsername>chemit</redmineUsername> + <redminePassword>azer</redminePassword> + <projectId>one</projectId> + <versionId>1.0.0</versionId> + <dataType>files</dataType> + <dataFormat>xml</dataFormat> + <verbose>true</verbose> + </configuration> + <executions> + <execution> + <goals> + <goal>get-project-version-data</goal> + </goals> + </execution> + </executions> + </plugin> + </plugins> + </build> +</project> \ No newline at end of file Added: maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version-issues.xml =================================================================== --- maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version-issues.xml (rev 0) +++ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version-issues.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,38 @@ +<?xml version="1.0" encoding="UTF-8"?> +<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"> + + <groupId>org.nuiton.maven-redmine-plugin</groupId> + <artifactId>test-generate-changes</artifactId> + <version>0</version> + + <name>generate-changes</name> + + <build> + + <plugins> + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-redmine-plugin</artifactId> + <configuration> + <redmineUrl>http://mynuiton.org</redmineUrl> + <redmineUsername>chemit</redmineUsername> + <redminePassword>azer</redminePassword> + <projectId>one</projectId> + <versionId>1.0.0</versionId> + <dataType>issues</dataType> + <dataFormat>xml</dataFormat> + <verbose>true</verbose> + </configuration> + <executions> + <execution> + <goals> + <goal>get-project-version-data</goal> + </goals> + </execution> + </executions> + </plugin> + </plugins> + </build> +</project> \ No newline at end of file Added: maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version.xml =================================================================== --- maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version.xml (rev 0) +++ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/GetProjectVersionDataMojoTest/get-version.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,38 @@ +<?xml version="1.0" encoding="UTF-8"?> +<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"> + + <groupId>org.nuiton.maven-redmine-plugin</groupId> + <artifactId>test-generate-changes</artifactId> + <version>0</version> + + <name>generate-changes</name> + + <build> + + <plugins> + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-redmine-plugin</artifactId> + <configuration> + <redmineUrl>http://mynuiton.org</redmineUrl> + <redmineUsername>chemit</redmineUsername> + <redminePassword>azer</redminePassword> + <projectId>one</projectId> + <versionId>1.0.0</versionId> + <dataType>version</dataType> + <dataFormat>xml</dataFormat> + <verbose>true</verbose> + </configuration> + <executions> + <execution> + <goals> + <goal>get-project-version-data</goal> + </goals> + </execution> + </executions> + </plugin> + </plugins> + </build> +</project> \ No newline at end of file Added: maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/RedmineReportMojoTest/redmine-report.xml =================================================================== --- maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/RedmineReportMojoTest/redmine-report.xml (rev 0) +++ maven-redmine-plugin/trunk/src/test/resources/org/nuiton/redmine/plugin/RedmineReportMojoTest/redmine-report.xml 2009-09-06 19:06:37 UTC (rev 18) @@ -0,0 +1,33 @@ +<?xml version="1.0" encoding="UTF-8"?> +<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"> + + <groupId>org.nuiton.maven-redmine-plugin</groupId> + <artifactId>test-redmine-report</artifactId> + <version>0</version> + + <name>redmine-report</name> + + <build> + + <plugins> + <plugin> + <groupId>org.nuiton</groupId> + <artifactId>maven-redmine-plugin</artifactId> + <configuration> + <redmineUrl>http://mynuiton.org</redmineUrl> + <redmineUsername>chemit</redmineUsername> + <redminePassword>azer</redminePassword> + </configuration> + <executions> + <execution> + <goals> + <goal>redmine-report</goal> + </goals> + </execution> + </executions> + </plugin> + </plugins> + </build> +</project> \ No newline at end of file