wood burning stoves 2.0*
The moose likes Portals and Portlets and the fly likes uPortal 3.2.4 Build Failed Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login


Win a copy of Android Security Essentials Live Lessons this week in the Android forum!
JavaRanch » Java Forums » Java » Portals and Portlets
Bookmark "uPortal 3.2.4 Build Failed" Watch "uPortal 3.2.4 Build Failed" New topic
Author

uPortal 3.2.4 Build Failed

Amir Rana
Greenhorn

Joined: Apr 11, 2011
Posts: 1
Hi,

I am trying to install uPortal 3.2.4 from a quickstart and using the following versions,

Apache Ant 1.7.1
Apache Maven 2.2.1
Apache Tomcat 6.0.24
HSQLDB
uPortal 3.2.4

I have configured the files according the the instructions on uPortal website, https://wiki.jasig.org/pages/viewpage.action?pageId=29133275


I initialised by:
C:\uPortal-3.2.4-quick-start\uPortal-3.2.4>ant initportal

Then it ran for 8 mins giving me all Build Successful messages then the below is the message returned by command prompt with the details.


prodPrompt:

initdb:
[echo] Initializing database

prodPrompt:

db:
[echo] Artifact 'C:\uPortal-3.2.4-quick-start\uPortal-3.2.4\uportal-impl\ta
rget/uportal-impl-3.2.4.jar' is up-to-date
[artifact:install] [INFO] Installing C:\uPortal-3.2.4-quick-start\uPortal-3.2.4\
uportal-impl\target\uportal-impl-3.2.4.jar to C:\Documents and Settings\uvab008\
.m2\repository\org\jasig\portal\uportal-impl\3.2.4\uportal-impl-3.2.4.jar
[echo] Invoking DbLoader
[java] INFO Creating new lazily initialized GenericApplicationContext for
the portal
[java] INFO Created new MemoryContext with environment '{java.naming.facto
ry.url.pkgs=tyrex.naming, java.naming.provider.url=, java.naming.factory.initial
=org.jasig.portal.jndi.DisposableMemoryContextFactory}'
[java] INFO Initialized portal JNDI context
[java] INFO Setting CacheProvider 'org.jasig.portal.utils.cache.hibernate.
EhCacheProvider@650646' on ThreadLocal
[java] WARN Could not obtain connection metadata
[java] org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableCo
nnectionFactory (socket creation error)
[java] at org.apache.commons.dbcp.BasicDataSource.createPoolableConnect
ionFactory(BasicDataSource.java:1549)
[java] at org.apache.commons.dbcp.BasicDataSource.createDataSource(Basi
cDataSource.java:1388)
[java] at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDa
taSource.java:1044)
[java] at org.hibernate.ejb.connection.InjectedDataSourceConnectionProv
ider.getConnection(InjectedDataSourceConnectionProvider.java:47)
[java] at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFacto
ry.java:84)
[java] at org.hibernate.cfg.Configuration.buildSettings(Configuration.j
ava:2073)
[java] at org.hibernate.cfg.Configuration.buildSessionFactory(Configura
tion.java:1298)
[java] at org.hibernate.cfg.AnnotationConfiguration.buildSessionFactory
(AnnotationConfiguration.java:859)
[java] at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory
(Ejb3Configuration.java:669)
[java] at org.hibernate.ejb.HibernatePersistence.createContainerEntityM
anagerFactory(HibernatePersistence.java:132)
[java] at org.springframework.orm.jpa.LocalContainerEntityManagerFactor
yBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.ja
va:224)
[java] at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.
afterPropertiesSet(AbstractEntityManagerFactoryBean.java:291)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1369)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1335)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:473)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
[java] at java.security.AccessController.doPrivileged(Native Method)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
$1.getObject(AbstractBeanFactory.java:264)
[java] at org.springframework.beans.factory.support.DefaultSingletonBea
nRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
.doGetBean(AbstractBeanFactory.java:261)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
.getBean(AbstractBeanFactory.java:185)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
.getBean(AbstractBeanFactory.java:164)
[java] at org.springframework.beans.factory.support.BeanDefinitionValue
Resolver.resolveReference(BeanDefinitionValueResolver.java:269)
[java] at org.springframework.beans.factory.support.BeanDefinitionValue
Resolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:104)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1245
)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1010)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:472)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
[java] at java.security.AccessController.doPrivileged(Native Method)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
$1.getObject(AbstractBeanFactory.java:264)
[java] at org.springframework.beans.factory.support.DefaultSingletonBea
nRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
.doGetBean(AbstractBeanFactory.java:261)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
.getBean(AbstractBeanFactory.java:185)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
.getBean(AbstractBeanFactory.java:164)
[java] at org.springframework.beans.factory.support.BeanDefinitionValue
Resolver.resolveReference(BeanDefinitionValueResolver.java:269)
[java] at org.springframework.beans.factory.support.BeanDefinitionValue
Resolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:104)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1245
)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1010)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:472)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
[java] at java.security.AccessController.doPrivileged(Native Method)
[java] at org.springframework.beans.factory.support.AbstractAutowireCap
ableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
$1.getObject(AbstractBeanFactory.java:264)
[java] at org.springframework.beans.factory.support.DefaultSingletonBea
nRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
.doGetBean(AbstractBeanFactory.java:261)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
.getBean(AbstractBeanFactory.java:185)
[java] at org.springframework.beans.factory.support.AbstractBeanFactory
.getBean(AbstractBeanFactory.java:164)
[java] at org.springframework.beans.factory.support.DefaultListableBean
Factory.preInstantiateSingletons(DefaultListableBeanFactory.java:429)
[java] at org.springframework.context.support.AbstractApplicationContex
t.finishBeanFactoryInitialization(AbstractApplicationContext.java:728)
[java] at org.springframework.context.support.AbstractApplicationContex
t.refresh(AbstractApplicationContext.java:380)
[java] at org.jasig.portal.spring.PortalApplicationContextLocator$Porta
lApplicationContextCreator.createSingleton(PortalApplicationContextLocator.java:
178)
[java] at org.jasig.portal.spring.PortalApplicationContextLocator$Porta
lApplicationContextCreator.createSingleton(PortalApplicationContextLocator.java:
165)
[java] at org.jasig.portal.utils.threading.SingletonDoubleCheckedCreato
r.create(SingletonDoubleCheckedCreator.java:56)
[java] at org.jasig.portal.utils.threading.DoubleCheckedCreator.get(Dou
bleCheckedCreator.java:100)
[java] at org.jasig.portal.spring.PortalApplicationContextLocator.getAp
plicationContext(PortalApplicationContextLocator.java:141)
[java] at org.jasig.portal.tools.dbloader.DbLoaderRunner.main(DbLoaderR
unner.java:59)
[java] Caused by: java.sql.SQLException: socket creation error
[java] at org.hsqldb.jdbc.Util.sqlException(Unknown Source)
[java] at org.hsqldb.jdbc.jdbcConnection.<init>(Unknown Source)
[java] at org.hsqldb.jdbcDriver.getConnection(Unknown Source)
[java] at org.hsqldb.jdbcDriver.connect(Unknown Source)
[java] at org.apache.commons.dbcp.DriverConnectionFactory.createConnect
ion(DriverConnectionFactory.java:38)
[java] at org.apache.commons.dbcp.PoolableConnectionFactory.makeObject(
PoolableConnectionFactory.java:582)
[java] at org.apache.commons.dbcp.BasicDataSource.validateConnectionFac
tory(BasicDataSource.java:1556)
[java] at org.apache.commons.dbcp.BasicDataSource.createPoolableConnect
ionFactory(BasicDataSource.java:1545)
[java] ... 57 more
[java] INFO Created new lazily initialized GenericApplicationContext for t
he portal in 20229ms
[java] INFO Dropping existing tables
[java] INFO drop table UP_VERSIONS if exists
[java] Exception in thread "main" org.springframework.jdbc.CannotGetJdbcCon
nectionException: Could not get JDBC Connection; nested exception is org.apache.
commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (socket
creation error)
[java] at org.springframework.jdbc.datasource.DataSourceUtils.getConnec
tion(DataSourceUtils.java:82)
[java] at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTempla
te.java:382)
[java] at org.springframework.jdbc.core.JdbcTemplate.update(JdbcTemplat
e.java:522)
[java] at org.jasig.portal.tools.dbloader.HibernateDbLoader.process(Hib
ernateDbLoader.java:127)
[java] at org.jasig.portal.tools.dbloader.DbLoaderRunner.main(DbLoaderR
unner.java:61)
[java] Caused by: org.apache.commons.dbcp.SQLNestedException: Cannot create
PoolableConnectionFactory (socket creation error)
[java] at org.apache.commons.dbcp.BasicDataSource.createPoolableConnect
ionFactory(BasicDataSource.java:1549)
[java] at org.apache.commons.dbcp.BasicDataSource.createDataSource(Basi
cDataSource.java:1388)
[java] at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDa
taSource.java:1044)
[java] at org.springframework.jdbc.datasource.DataSourceUtils.doGetConn
ection(DataSourceUtils.java:113)
[java] at org.springframework.jdbc.datasource.DataSourceUtils.getConnec
tion(DataSourceUtils.java:79)
[java] ... 4 more
[java] Caused by: java.sql.SQLException: socket creation error
[java] at org.hsqldb.jdbc.Util.sqlException(Unknown Source)
[java] at org.hsqldb.jdbc.jdbcConnection.<init>(Unknown Source)
[java] at org.hsqldb.jdbcDriver.getConnection(Unknown Source)
[java] at org.hsqldb.jdbcDriver.connect(Unknown Source)
[java] at org.apache.commons.dbcp.DriverConnectionFactory.createConnect
ion(DriverConnectionFactory.java:38)
[java] at org.apache.commons.dbcp.PoolableConnectionFactory.makeObject(
PoolableConnectionFactory.java:582)
[java] at org.apache.commons.dbcp.BasicDataSource.validateConnectionFac
tory(BasicDataSource.java:1556)
[java] at org.apache.commons.dbcp.BasicDataSource.createPoolableConnect
ionFactory(BasicDataSource.java:1545)
[java] ... 8 more

BUILD FAILED
C:\uPortal-3.2.4-quick-start\uPortal-3.2.4\build.xml:128: The following error oc
curred while executing this line:
C:\uPortal-3.2.4-quick-start\uPortal-3.2.4\build.xml:134: The following error oc
curred while executing this line:
C:\uPortal-3.2.4-quick-start\uPortal-3.2.4\build.xml:180: The following error oc
curred while executing this line:
C:\uPortal-3.2.4-quick-start\uPortal-3.2.4\build.xml:903: The following error oc
curred while executing this line:
C:\uPortal-3.2.4-quick-start\uPortal-3.2.4\build.xml:906: The following error oc
curred while executing this line:
C:\uPortal-3.2.4-quick-start\uPortal-3.2.4\build.xml:191: Java returned: 1

Total time: 8 minutes 50 seconds
C:\uPortal-3.2.4-quick-start\uPortal-3.2.4>



My Build.xml File:

<!--

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

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

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

-->

<!--
| Detailed help documenation lives in docs/antHelp.txt, please refer to this file or
| run 'ant help' for usage of this file.
|
| Comments in this file should be targeted to the maintenance of the build script.
+-->
<project name="uPortal" default="help" basedir="." xmlns:up="urn:up-util-ant" xmlns:artifact="urn:maven-artifact-ant">
<fail message="build.properties does not exist, please copy build.properties.sample and fill in your settings.">
<condition>
<not>
<available file="${basedir}/build.properties" />
</not>
</condition>
</fail>

<!--
| Load the build properties before the next fail tests since they check properties provided
| by the file.
+-->
<property environment="env" />
<property file="${basedir}/build.properties" />

<!--
| Setup temp directories
+-->
<property name="jasig.tmpdir" value="${java.io.tmpdir}/jasig" />
<mkdir dir="${jasig.tmpdir}" />
<chmod type="dir" dir="${jasig.tmpdir}" perm="ugo+rxws" />

<tempfile property="parentPomInstallMarker.file" destdir="${jasig.tmpdir}" prefix="uportal-parent.pom-" suffix="-marker" deleteonexit="true"/>

<!--
| Define maven.home and maven.settings variables if they are not set
+-->
<condition property="maven.home" value="${env.M2_HOME}">
<and>
<not>
<isset property="maven.home"/>
</not>
<available file="${env.M2_HOME}"/>
</and>
</condition>
<fail message="maven.home=${maven.home} does not exist.${line.separator}Either set maven.home in build.properties or set the M2_HOME environment variable.">
<condition>
<not>
<available file="${maven.home}" />
</not>
</condition>
</fail>

<condition property="maven.settings" value="${user.home}/.ant/settings.xml">
<and>
<not>
<isset property="maven.settings"/>
</not>
<available file="${user.home}/.ant/settings.xml"/>
</and>
</condition>
<condition property="maven.settings" value="${user.home}/.m2/settings.xml">
<and>
<not>
<isset property="maven.settings"/>
</not>
<available file="${user.home}/.m2/settings.xml"/>
</and>
</condition>
<condition property="maven.settings" value="${maven.home}/conf/settings.xml">
<and>
<not>
<isset property="maven.settings"/>
</not>
<available file="${maven.home}/conf/settings.xml"/>
</and>
</condition>
<fail message="maven.settings=${maven.settings} does not exist.${line.separator}Either set maven.settings in build.properties or ensure one of the following files exist:${line.separator} - ${user.home}/.ant/settings.xml${line.separator} - ${user.home}/.m2/settings.xml${line.separator} - ${maven.home}/conf/settings.xml">
<condition>
<not>
<available file="${maven.settings}" />
</not>
</condition>
</fail>

<!--
| Properties that describe the maven project
+-->
<property name="bootstrap.dir" value="${basedir}/bootstrap" />
<property name="uportal-impl.dir" value="${basedir}/uportal-impl" />
<property name="uportal-war.dir" value="${basedir}/uportal-war" />
<property name="uportal-portlets-overlay.dir" value="${basedir}/uportal-portlets-overlay" />
<property name="uportal-ear.dir" value="${basedir}/uportal-ear" />

<import file="${bootstrap.dir}/build_includes.xml" />


<!-- ============================== Public Targets ============================== -->

<target name="help" description="Prints information about using this ant build file.">
<loadfile property="helpMessage" srcFile="docs/antHelp.txt" />
<echo message="${helpMessage}" />
</target>

<target name="initportal" depends="prodPrompt" description="Runs all the targets necessary to deploy the portal and prepare the portal database">
<echo message="Initializing uPortal" />
<antcall target="deploy-ear">
<param name="removeExisting" value="true" />
</antcall>
<antcall target="initdb" />
<echo message="Finished initializing uPortal" />
</target>

<target name="initdb" depends="prodPrompt" description="Drops all tables, then runs all the targets necessary prepare the portal database">
<echo message="Initializing database" />
<antcall target="db" />
<antcall target="db-hibernate" />
<antcall target="i18n-db" />
<antcall target="db-import" />
<echo message="Finished initializing database" />
</target>

<target name="db-hibernate" depends="prodPrompt" description="Drops then creates Hibernate managed tables">
<antcall target="db-hibernate-portal" />
<antcall target="db-hibernate-stats" />
</target>

<target name="db-hibernate-portal" depends="prodPrompt" description="Drops then creates Hibernate managed tables for the portal">
<uportal-impl-macro>
<java fork="true" failonerror="true" dir="${uportal-impl.dir}" classname="org.jasig.portal.tools.dbloader.DataSourceSchemaExportRunner">
<sysproperty key="log4j.configuration" value="command-line.log4j.properties" />

<classpath refid="uportal-impl-full.classpath" />

<arg value="-b" />
<arg value="portalDbHibernateExport" />
<arg value="-e" />
<arg value="-d" />
<arg value="-c" />
</java>
</uportal-impl-macro>
</target>

<target name="db-hibernate-stats" depends="prodPrompt" description="Drops then creates Hibernate managed tables used for the database backed portal statistics">
<uportal-impl-macro>
<java fork="true" failonerror="true" dir="${uportal-impl.dir}" classname="org.jasig.portal.tools.dbloader.DataSourceSchemaExportRunner">
<sysproperty key="log4j.configuration" value="command-line.log4j.properties" />

<classpath refid="uportal-impl-full.classpath" />

<arg value="-b" />
<arg value="statsDbHibernateExport" />
<arg value="-e" />
<arg value="-d" />
<arg value="-c" />
<arg value="-i" />
</java>
</uportal-impl-macro>
</target>

<target name="db" depends="prodPrompt" description="Loads database tables and data">
<uportal-impl-macro>
<property name="usetable" value="-t" />
<property name="tablefile" value="/properties/db/tables.xml" />
<property name="usedata" value="-d" />
<property name="datafile" value="/properties/db/data.xml" />
<property name="createscript" value=" " />
<property name="droptables" value="-D" />
<property name="createtables" value="-C" />
<property name="populatetables" value="-P" />

<echo message="Invoking DbLoader" />
<java fork="true" failonerror="true" dir="${uportal-impl.dir}" classname="org.jasig.portal.tools.dbloader.DbLoaderRunner">
<sysproperty key="log4j.configuration" value="command-line.log4j.properties" />

<classpath refid="uportal-impl-full.classpath" />

<arg value="${usetable}" />
<arg value="${tablefile}" />
<arg value="${usedata}" />
<arg value="${datafile}" />
<arg value="${createscript}" />
<arg value="${droptables}" />
<arg value="${createtables}" />
<arg value="${populatetables}" />
</java>
</uportal-impl-macro>
</target>

<target name="i18n-db" depends="prodPrompt" description="Loads internationalization tables and data">
<echo message="Invoking DbLoader for localizationed database setting" />
<antcall target="db">
<param name="usetable" value="-t" />
<param name="tablefile" value="/properties/db/tables-i18n.xml" />
<param name="usedata" value="-d" />
<param name="datafile" value="/properties/db/data-i18n.xml" />
<param name="droptables" value="-D" />
<param name="createtables" value="-C" />
<param name="populatetables" value="-P" />
</antcall>
</target>

<target name="db-import" depends="prodPrompt" description="Imports the default XML files to the database">
<echo message="Importing data" />
<antcall target="crn-import">
<param name="dir" value="${basedir}/uportal-impl/src/main/resources/properties/db/base_entities/" />
<param name="noprompt" value="true" />
</antcall>
<!-- Use build.properties to override the entities.location setting -->
<property name="entities.location" value="uportal-impl/src/main/resources/properties/db/entities/" />
<antcall target="crn-import">
<param name="dir" value="${basedir}/${entities.location}" />
<param name="noprompt" value="true" />
</antcall>
</target>

<target name="dbtest" description="Displays information about the database defined in rdbm.properties">
<uportal-impl-macro>
<echo message="Invoking DbTest" />
<java fork="true" failonerror="true" dir="${basedir}" classname="org.jasig.portal.tools.DbTest">
<sysproperty key="log4j.configuration" value="command-line.log4j.properties" />

<classpath refid="uportal-impl-full.classpath" />
</java>
</uportal-impl-macro>
</target>

<target name="regchantype" depends="prodPrompt" description="Registers a new channel type">
<uportal-impl-macro>
<property name="class" value=" " />
<property name="name" value=" " />
<property name="description" value=" " />
<property name="uri" value=" " />

<echo message="Invoking RegisterChannelType" />
<java dir="${basedir}" classname="org.jasig.portal.tools.RegisterChannelType">
<classpath refid="uportal-impl-full.classpath" />

<arg value="${class}" />
<arg value="${name}" />
<arg value="${description}" />
<arg value="${uri}" />
</java>
</uportal-impl-macro>
</target>

<target name="crn-export" description="Exports the specified entity or entities to XML on the file system">
<uportal-impl-macro>
<!-- Three properties control the export: dir, type, and sysid -->
<fail unless="type">
You must specify a "type" parameter (-Dtype={something}) from the following: all, layout,
all-layouts, channel, all-channels, all-permissions, all-memberships, group, all-groups, user,
all-users.
</fail>

<property name="dir" value="." />
<property name="sysid" value="" />

<!-- Invoke Cernunnos specifying script and parameters -->
<java fork="true" failonerror="true" dir="${basedir}" classname="org.danann.cernunnos.runtime.Main">
<sysproperty key="log4j.configuration" value="command-line.log4j.properties" />
<classpath refid="uportal-impl-full.classpath" />
<arg value="classpath://org/jasig/portal/io/export.crn" />
<arg value="${dir}" />
<arg value="${type}" />
<arg value="${sysid}" />
</java>
</uportal-impl-macro>
</target>

<target name="crn-import" depends="prodPrompt" description="Imports the specified XML file or files">
<uportal-impl-macro>
<!-- Two properties control the import: dir and pattern -->
<property name="dir" value="." />
<property name="pattern" value="org.jasig.portal.FilePatternPhrase.USE_DEFAULT_VALUE"/>
<property name="noprompt" value="false"/>

<!-- Invoke Cernunnos specifying script and parameters -->
<java fork="true" failonerror="true" dir="${basedir}" classname="org.danann.cernunnos.runtime.Main">
<sysproperty key="log4j.configuration" value="command-line.log4j.properties" />
<classpath refid="uportal-impl-full.classpath" />
<arg value="classpath://org/jasig/portal/io/import.crn" />
<arg value="${dir}" />
<arg value="${pattern}" />
<arg value="${noprompt}" />
</java>
</uportal-impl-macro>
</target>

<target name="crn-delete" depends="prodPrompt" description="Deletes the specified entity">
<uportal-impl-macro>
<fail unless="type">
You must specify a "type" parameter (-Dtype={something}) from the following: layout, channel,
group, user.
</fail>

<fail unless="sysid">
You must specify a "sysid" parameter (-Dsysid={something}). The value will be a valid username
(user or layout), fname (channel), or name (group).
</fail>

<!-- Invoke Cernunnos specifying script and parameters -->
<java fork="true" failonerror="true" dir="${basedir}" classname="org.danann.cernunnos.runtime.Main">
<classpath refid="uportal-impl-full.classpath" />
<arg value="classpath://org/jasig/portal/io/delete.crn" />
<arg value="${type}" />
<arg value="${sysid}" />
</java>
</uportal-impl-macro>
</target>

<target name="crn-make-data-xml" description="Runs the DbUnload tool against all tables listed in data.xml">
<uportal-impl-macro>

<!-- Invoke Cernunnos specifying script and parameters -->
<java fork="true" failonerror="true" dir="${basedir}" classname="org.danann.cernunnos.runtime.Main">
<classpath refid="uportal-impl-full.classpath" />
<arg value="classpath://org/jasig/portal/tools/dbloader/dbunload.crn" />
</java>
</uportal-impl-macro>
</target>

<target name="clean-shared" depends="checkForTomcat" description="Removes the ALL shared libraries from the container.">
<mkdir dir="${server.base}/shared/lib"/>
<delete>
<fileset dir="${server.base}/shared/lib">
<include name="*"/>
</fileset>
</delete>
</target>

<target name="clean-tomcat" depends="checkForTomcat" description="Removes the deployed uPortal from the container">
<uportal-parent-macro>
<!-- Clean out uPortal from Tomcat -->
<artifact:pom file="${uportal-war.dir}/pom.xml" id="uportal-war.pom" settingsFile="${maven.settings}"/>
<property name="destDir" value="${server.base}/webapps/${uportal-war.pom.build.finalName}" />
<echo>Deleting '${destDir}'</echo>
<delete dir="${destDir}" />
</uportal-parent-macro>
</target>

<target name="clean" description="Runs 'mvn clean'">
<!-- Execute the mvn clean lifecycle -->
<antcall target="mvn">
<param name="pomDir" value="${basedir}" />
<param name="goal" value="clean" />
</antcall>
</target>

<target name="deploy-ear" depends="checkForTomcat" description="Deploy uPortal and dependent libraries and portlets to the servlet container">
<uportal-ear-macro>
<echo message=" extractWars=${extractWars}" />
<echo message="removeExisting=${removeExisting}" />
<echo message=" cleanShared=${cleanShared}" />

<if>
<equals arg1="${cleanShared}" arg2="true" />
<then>
<antcall target="clean-shared" />
</then>
</if>

<artifact:dependencies pathid="uportal-ant" settingsFile="${maven.settings}">
<pom file="${bootstrap.dir}/uportal-ant-tasks/pom.xml" />
</artifact:dependencies>

<typedef resource="org/jasig/portal/ant/antlib.xml" uri="urn:up-util-ant">
<classpath>
<path refid="uportal-ant" />
</classpath>
</typedef>

<mkdir dir="${server.base}/shared/lib"/>
<up:tomcatEarDeploy ear="${uportal-ear.artifact}" catalinaBase="${server.base}" webAppsDir="${server.webapps}" extractWars="${extractWars}" removeExistingDirectories="${removeExisting}" />
</uportal-ear-macro>
</target>

<target name="deploy-war" depends="checkForTomcat" description="Deploy the uPortal web application to the servlet container">
<uportal-war-macro>
<antcall target="fastWarDeploy">
<param name="warPath" value="${uportal-war.artifact}"/>
</antcall>
</uportal-war-macro>
</target>

<target name="deployPortletApp" depends="checkForTomcat" description="Deploys a portlet application">
<!-- Check arguments -->
<fail message="'-DportletApp=[WAR File]' must be specified">
<condition>
<not>
<isset property="portletApp" />
</not>
</condition>
</fail>

<if>
<available file="${user.dir}/${portletApp}" />
<then>
<property name="portletAppPath" location="${user.dir}/${portletApp}"/>
</then>
<else>
<property name="portletAppPath" location="${portletApp}"/>
</else>
</if>
<fail message="portletApp '${portletAppPath}' does not exist">
<condition>
<not>
<available file="${portletAppPath}" />
</not>
</condition>
</fail>


<basename property="war.filename" file="${portletAppPath}" />

<uportal-parent-macro>
<artifact:dependencies pathid="pluto-ant" settingsFile="${maven.settings}">
<artifact:pom file="${bootstrap.dir}/pluto-assembler/pom.xml" settingsFile="${maven.settings}" />
</artifact:dependencies>

<taskdef classname="org.apache.pluto.ant.AssembleTask" name="assemblePortlet">
<classpath>
<path refid="pluto-ant" />
</classpath>
</taskdef>
</uportal-parent-macro>

<assemblePortlet destdir="${jasig.tmpdir}" war="${portletAppPath}" />

<antcall target="fastWarDeploy">
<param name="warPath" value="${jasig.tmpdir}/${war.filename}"/>
</antcall>

<delete file="${jasig.tmpdir}/${war.filename}" />
</target>


<target name="md5passwd" depends="prodPrompt" description="Creates a user in the UP_PERSON_DIR table">
<uportal-impl-macro>
<property name="username" value=" " />

<echo message="Invoking Md5Passwd" />
<java dir="${basedir}" classname="org.jasig.portal.security.Md5Passwd">
<classpath refid="uportal-impl-full.classpath" />

<arg value="-c" />
<arg value="${username}" />
</java>
</uportal-impl-macro>
</target>

<target name="deluser" depends="prodPrompt" description="Delete traces of a user from the portal database">
<uportal-impl-macro>
<property name="user" value=" " />

<echo message="Invoking DeleteUser" />
<java dir="${basedir}" classname="org.jasig.portal.tools.DeleteUser" fork="true">
<classpath refid="uportal-impl-full.classpath" />

<arg value="${user}" />
</java>
</uportal-impl-macro>
</target>

<target name="addstylesheet" depends="prodPrompt" description="Registers a new theme or structure">
<uportal-impl-macro>
<property name="stylesheetType" value=" " />
<property name="stylesheetUri" value=" " />
<property name="descriptionUri" value=" " />

<echo message="Invoking RegisterStylesheet (add)" />
<java dir="${basedir}" fork="true" classname="org.jasig.portal.tools.RegisterStylesheet">
<classpath refid="uportal-impl-full.classpath" />

<arg value="${stylesheetType}" />
<arg value="${stylesheetUri}" />
<arg value="${descriptionUri}" />
</java>
</uportal-impl-macro>
</target>

<target name="modstylesheet" depends="prodPrompt" description="Modifies an existing theme or structure">
<uportal-impl-macro>
<property name="stylesheetType" value=" " />
<property name="stylesheetUri" value=" " />
<property name="descriptionUri" value=" " />
<property name="stylesheetId" value=" " />

<echo message="Invoking RegisterStylesheet (modify)" />
<java dir="${basedir}" fork="true" classname="org.jasig.portal.tools.RegisterStylesheet">
<classpath refid="uportal-impl-full.classpath" />

<arg value="${stylesheetType}" />
<arg value="-u" />
<arg value="${stylesheetUri}" />
<arg value="${descriptionUri}" />
<arg value="${stylesheetId}" />
</java>
</uportal-impl-macro>
</target>

<target name="delstylesheet" depends="prodPrompt" description="Deletes an existing theme or structure">
<uportal-impl-macro>
<property name="stylesheetType" value=" " />
<property name="stylesheetId" value=" " />

<echo message="Invoking RegisterStylesheet (delete)" />
<java dir="${basedir}" classname="org.jasig.portal.tools.RegisterStylesheet">
<classpath refid="uportal-impl-full.classpath" />

<arg value="${stylesheetType}" />
<arg value="-d" />
<arg value="${stylesheetId}" />
</java>
</uportal-impl-macro>
</target>

<target name="hsql" description="Start a HSQLDB instance consistent with the default RDBMS requirements of uPortal">
<property name="spawn" value="false" />

<condition property="failonerror" value="false">
<equals arg1="${spawn}" arg2="true" />
</condition>
<property name="failonerror" value="true" />

<uportal-parent-macro>
<artifact:dependencies pathid="hsql.classpath" settingsFile="${maven.settings}">
<artifact:pom file="${bootstrap.dir}/hsqldb/pom.xml" settingsFile="${maven.settings}" />
</artifact:dependencies>

<property name="database" value="${basedir}/data/uP3_uPortal" />
<property name="port" value="8887" />

<echo message="Starting HSQL" />
<echo message="Using: ${database}" />
<java fork="true" spawn="${spawn}" maxmemory="16M" dir="${basedir}" classname="org.hsqldb.Server" failonerror="${failonerror}">
<classpath refid="hsql.classpath" />

<arg value="-database" />
<arg value="${database}" />
<arg value="-port" />
<arg value="${port}" />
</java>
</uportal-parent-macro>
</target>

<target name="hsql-shutdown" description="Compacts then cleanly shuts down hsql, useful if the 'hsql' task was run with '-Dspawn=true'">
<uportal-parent-macro>
<artifact:dependencies pathid="hsql.classpath" settingsFile="${maven.settings}">
<artifact:pom file="${bootstrap.dir}/hsqldb/pom.xml" settingsFile="${maven.settings}" />
</artifact:dependencies>

<echo message="Stopping HSQL" />
<trycatch reference="hsql-shutdown.exceptionId">
<try>
<java fork="true" maxmemory="8M" dir="${basedir}" classname="org.hsqldb.util.SqlTool" timeout="5000" errorproperty="hsql-shutdown.err.out" failonerror="true">
<classpath refid="hsql.classpath" />

<arg value="--rcFile" />
<arg value="${bootstrap.dir}/hsqldb.sqltool.rc" />
<arg value="--sql" />
<arg value="shutdown compact" />
<arg value="uPortalDb" />
</java>
</try>
<catch>
<if>
<contains string="${hsql-shutdown.err.out}" substring="java.sql.SQLException: socket creation error" />
<then>
<echo>HSQL is not running</echo>
</then>
<else>
<echo>${jvm.err.out}</echo>
<throw refid="hsql-shutdown.exceptionId" />
</else>
</if>
</catch>
</trycatch>
</uportal-parent-macro>
</target>

<!-- ============================== Utility Targets ============================== -->
<!--
| Utility to deploy a WAR to the container where the delete and the replacement happen
| as close together as possible.
+-->
<target name="fastWarDeploy">
<fail message="'-DwarPath=[WAR File]' must be specified">
<condition>
<not>
<isset property="warPath" />
</not>
</condition>
</fail>

<basename property="war.contextname" file="${warPath}" suffix=".war" />
<property name="war.dest" value="${server.webapps}/${war.contextname}" />

<echo message=" extractWars=${extractWars}" />
<echo message="removeExisting=${removeExisting}" />

<if>
<os family="windows" />
<then>
<if>
<istrue value="${removeExisting}" />
<then>
<delete dir="${war.dest}" failonerror="false" />
<delete file="${war.dest}.war" failonerror="false" />
</then>
</if>

<if>
<istrue value="${extractWars}" />
<then>
<mkdir dir="${war.dest}" />
<unwar dest="${war.dest}" src="${warPath}" overwrite="true" />
</then>
<else>
<copy file="${warPath}" todir="${server.webapps}" />
</else>
</if>
</then>
<else>
<if>
<istrue value="${extractWars}" />
<then>
<property name="tempWarDir" value="${jasig.tmpdir}/${war.contextname}" />

<delete dir="${tempWarDir}" />
<mkdir dir="${tempWarDir}" />
<unwar dest="${tempWarDir}" src="${warPath}" overwrite="true" />

<if>
<istrue value="${removeExisting}" />
<then>
<delete dir="${war.dest}" />
<delete file="${war.dest}.war" />
</then>
</if>

<echo message="Moving ${tempWarDir} to ${server.webapps}" />
<move todir="${server.webapps}" file="${tempWarDir}" />
</then>
<else>
<if>
<istrue value="${removeExisting}" />
<then>
<delete dir="${war.dest}" />
<delete file="${war.dest}.war" />
</then>
</if>

<copy file="${warPath}" todir="${server.webapps}" />
</else>
</if>
</else>
</if>
</target>

<target name="prodPrompt">
<if>
<and>
<istrue value="${prodPrompt}" />
<not>
<isset property="continueWithProdTarget" />
</not>
</and>
<then>
<echo>WARNING: This task may change or destroy data and should be run with care in production environments.</echo>
<input message="Do you want to continue: " validargs="y,n" addproperty="continueWithProdTarget"/>
<condition property="do.abort">
<equals arg1="n" arg2="${continueWithProdTarget}"/>
</condition>
<fail if="do.abort">Task aborted by user.</fail>
</then>
</if>
</target>

<target name="checkForTomcat">
<fail message="server.base build property must be set.">
<condition>
<not>
<isset property="server.base" />
</not>
</condition>
</fail>
<fail message="The server.base build property refers to a non-existant location '${server.base}'">
<condition>
<not>
<available file="${server.base}" type="dir" />
</not>
</condition>
</fail>
</target>

<!-- ============================== Deprecated Targets ============================== -->
<target name="all">
<echo>The "all" Ant task is no longer supported. Run 'mvn clean compile' for the same result.</echo>
<fail message="The 'all' Ant task is no longer supported. Run 'mvn clean compile' for the same result.">
</fail>
</target>
<target name="compile">
<echo>The "compile" Ant task is no longer supported. Run 'mvn compile' for the same result.</echo>
<fail message="The 'compile' Ant task is no longer supported. Run 'mvn compile' for the same result.">
</fail>
</target>
<target name="compiletests">
<echo>The "compiletests" Ant task is no longer supported. Run 'mvn test-compile' for the same result.</echo>
<fail message="The 'compiletests' Ant task is no longer supported. Run 'mvn test-compile' for the same result.">
</fail>
</target>
<target name="deploy">
<echo>The "deploy" Ant task is no longer supported. Run 'ant deploy-war' for the same result.</echo>
<fail message="The 'deploy' Ant task is no longer supported. Run 'ant deploy-war' for the same result.">
</fail>
</target>
<target name="dist">
<echo>The "dist" Ant task is no longer supported. Run 'mvn package site' for a similar result.</echo>
<fail message="The 'dist' Ant task is no longer supported. Run 'mvn package site' for the same result.">
</fail>
</target>
<target name="javadoc">
<echo>The "javadoc" Ant task is no longer supported. Run 'mvn javadoc:javadoc' for the same result.</echo>
<fail message="The 'javadoc' Ant task is no longer supported. Run 'mvn javadoc:javadoc' for the same result.">
</fail>
</target>
<target name="runtests">
<echo>The "runtests" Ant task is no longer supported. Run 'mvn test' for the same result.</echo>
<fail message="The 'runtests' Ant task is no longer supported. Run 'mvn test' for the same result.">
</fail>
</target>
<target name="pubchan">
<echo>The "pubchan" Ant task is no longer supported. Use 'ant crn-import' to publish channel entity XML files.</echo>
<fail message="The 'pubchan' Ant task is no longer supported. Run 'ant crn-import' for the same result.">
</fail>
</target>


<!-- ============================== Maven Support Macros ============================== -->

<!--
| Macro that simply calls the install-root-pom target using an 'ant' task instead of the
| 'antcall' task to ensure the Maven tasks aren't tainted by a failed loading of the parent
| pom.
+-->
<macrodef name="uportal-parent-macro">
<element name="sub-tasks" optional="false" implicit="true" />
<sequential>
<!--
| Called via the <ant> task so the install happens in a different classloader. This
| is required so an initial install which is missing jasig-parent doesn't cause problems
| later due to the failed load of jasig-parent being cached.
+-->
<if>
<not>
<available file="${parentPomInstallMarker.file}" />
</not>
<then>
<ant antfile="${basedir}/build.xml" target="install-parent-pom" />
<touch file="${parentPomInstallMarker.file}" />
</then>
</if>

<sub-tasks />
</sequential>
</macrodef>

<target name="install-parent-pom">
<artifact:pom file="${basedir}/pom.xml" id="uportal-parent.pom" settingsFile="${maven.settings}" />
<artifact:install file="${basedir}/pom.xml" pomrefid="uportal-parent.pom" settingsFile="${maven.settings}" />
</target>

<!--
| Macro for tasks involving a maven project. The macro loads the pom, creates a classpath,
| ensures the project artifact is up-to-date, and runs the <sub-tasks> element. If the
| artifact is not up-to-date the <pre-package> element can be used to add behavior before
| 'mvn package' is called on the project.
|
| The following are available in the pre-package and sub-tasks elements:
| pom object - @{project-name}.pom - The Maven POM object for the project
| property - @{project-name}.artifact - The full path to the final artifact
| path - @{project-name}.classpath - The projects classpath not including the artifact
+-->
<macrodef name="maven-artifact-macro">
<attribute name="project-name" />
<attribute name="project-path" />
<attribute name="checkFilesId" default="null" />

<element name="sub-tasks" optional="true" implicit="true" />

<sequential>
<!--
| Load the pom & classpath
+-->
<artifact:pom file="@{project-path}/pom.xml" id="@{project-name}.pom" settingsFile="${maven.settings}" />
<artifact:dependencies pathid="@{project-name}.classpath" settingsFile="${maven.settings}">
<artifact:pom refid="@{project-name}.pom" settingsFile="${maven.settings}" />
</artifact:dependencies>

<!--
| Define the location of the resulting artifact
+-->
<property name="@{project-name}.artifact" value="${@{project-name}.pom.build.directory}/${@{project-name}.pom.build.finalName}.${@{project-name}.pom.packaging}" />

<!--
| Parse out the target directory without the preceding project path
+-->
<length property="@{project-name}.path.length" string="@{project-path}/" />
<propertyregex property="@{project-name}.build.directory" input="${@{project-name}.pom.build.directory}" regexp=".{${@{project-name}.path.length}}(.*)" select="\1" />

<!--
| Do uptodate checking for project files and dependencies
+-->
<uptodate property="@{project-name}.projectFilesUTD" targetfile="${@{project-name}.artifact}">
<srcfiles dir="@{project-path}" defaultexcludes="true">
<exclude name="${@{project-name}.build.directory}/" />
</srcfiles>
</uptodate>
<if>
<not>
<equals arg1="@{checkFilesId}" arg2="null" />
</not>
<then>
<uptodate property="@{project-name}.dependenciesUTD" targetfile="${@{project-name}.artifact}">
<srcfiles refid="@{checkFilesId}" />
</uptodate>
</then>
<else>
<property name="@{project-name}.dependenciesUTD" value="true" />
</else>
</if>

<!--
| Call 'mvn package' if files in the project are not up-to-date
+-->
<if>
<not>
<and>
<equals arg1="${@{project-name}.projectFilesUTD}" arg2="true" />
<equals arg1="${@{project-name}.dependenciesUTD}" arg2="true" />
</and>
</not>
<then>
<echo message="Artifact '${@{project-name}.artifact}' is not available or out-of-date, calling 'mvn install'" />

<!--
| Force the target artifact to be re-built by deleting it.
+-->
<delete file="${@{project-name}.artifact}" />

<antcall target="mvn">
<param name="pomDir" value="@{project-path}" />
<param name="goal" value="install" />
</antcall>
</then>
<else>
<echo message="Artifact '${@{project-name}.artifact}' is up-to-date" />
<artifact:install file="${@{project-name}.artifact}" pomrefid="@{project-name}.pom" settingsFile="${maven.settings}" />
</else>
</if>

<!--
| Execute the sub-tasks
+-->
<sub-tasks />
</sequential>
</macrodef>

<!--
| Provides a wrapper for tasks that need a classpath that includes the uPortal source
| and all of its dependencies. The task also ensures the uportal-impl JAR exists and
| is up to date.
|
| The following are available in the impl-sub-tasks element:
| pom object - uportal-impl.pom - The Maven POM object for the uportal-impl pom
| property - uportal-impl.artifact - The full path to the uportal-impl JAR
| path - uportal-impl.classpath - The uportal-impl classpath not including the uportal-impl JAR
| path - uportal-impl-full.classpath - The uportal-impl classpath including the uportal-impl JAR
+-->
<macrodef name="uportal-impl-macro">
<element name="impl-sub-tasks" optional="false" implicit="true" />

<sequential>
<uportal-parent-macro>
<fileset id="uportal-parent.pom.fsid" file="${basedir}/pom.xml" />

<maven-artifact-macro project-name="uportal-impl" project-path="${uportal-impl.dir}" checkfilesid="uportal-parent.pom.fsid">
<!--
| Include the uportal-impl JAR in the final classpath
+-->
<path id="uportal-impl-full.classpath">
<path refid="uportal-impl.classpath" />
<pathelement location="${uportal-impl.artifact}" />
</path>

<!--
| Execute the impl-sub-tasks
+-->
<impl-sub-tasks />
</maven-artifact-macro>
</uportal-parent-macro>
</sequential>
</macrodef>

<!--
| Provides a wrapper for tasks that need a classpath that includes all of the uPortal WAR
| dependencies. The task also ensures the uportal-war WAR exists and is up to date.
|
| The following are available in the war-sub-tasks element:
| properties from the uportal-impl-macro macrodef
| pom object - uportal-war.pom - The Maven POM object for the uportal-war pom
| property - uportal-war.artifact - The full path to the uportal-war WAR
| path - uportal-war.classpath - The uportal-war classpath not including the uportal-war WAR
+-->
<macrodef name="uportal-war-macro">
<element name="war-sub-tasks" optional="false" implicit="true" />

<sequential>
<uportal-impl-macro>
<fileset id="uportal-impl-artifacts" file="${uportal-impl.artifact}" />
<maven-artifact-macro project-name="uportal-war" project-path="${uportal-war.dir}" checkfilesid="uportal-impl-artifacts">
<!--
| Execute the war-sub-tasks
+-->
<war-sub-tasks />
</maven-artifact-macro>
</uportal-impl-macro>
</sequential>
</macrodef>

<!--
| Provides a wrapper for tasks that depend on the portlet overlays being installed and up-to-date.
|
| No properties are set for the overlay-sub-tasks element.
+-->
<macrodef name="uportal-portlets-overlay-macro">
<element name="overlay-sub-tasks" optional="false" implicit="true" />

<sequential>
<uportal-parent-macro>
<!--
| Install the overlay parent project pom
+-->
<artifact:pom file="${uportal-portlets-overlay.dir}/pom.xml" id="uportal-portlets-overlay.pom" settingsFile="${maven.settings}" />
<artifact:install file="${uportal-portlets-overlay.dir}/pom.xml" pomrefid="uportal-portlets-overlay.pom" settingsFile="${maven.settings}" />

<fileset id="uportal-portlets-overlay.pom.fsid" dir="${basedir}">
<filename name="${basedir}/pom.xml"/>
<filename name="${uportal-portlets-overlay.dir}/pom.xml"/>
</fileset>

<!--
| Iterate over the child projects and run the artifact macro on each of them
+-->
<for param="portlet-overlay-dir">
<path>
<dirset dir="${uportal-portlets-overlay.dir}">
<include name="*"/>
</dirset>
</path>
<sequential>
<if>
<available file="@{portlet-overlay-dir}/pom.xml" />
<then>
<basename file="@{portlet-overlay-dir}" property="@{portlet-overlay-dir}-name" />
<maven-artifact-macro project-name="${@{portlet-overlay-dir}-name}" project-path="@{portlet-overlay-dir}" checkfilesid="uportal-portlets-overlay.pom.fsid" />
</then>
</if>
</sequential>
</for>

<fileset id="portletWars.fsid" dir="${uportal-portlets-overlay.dir}">
<include name="*/target/*.war"/>
</fileset>

<!--
| Execute the overlay-sub-tasks
+-->
<overlay-sub-tasks />
</uportal-parent-macro>
</sequential>
</macrodef>

<!--
| Provides a wrapper for tasks that need a classpath that includes all of the uPortal EAR
| dependencies. The task also ensures the uportal-ear EAR exists and is up to date.
|
| The following are available in the ear-sub-tasks element:
| properties from the uportal-war-macro macrodef
| pom object - uportal-ear.pom - The Maven POM object for the uportal-ear pom
| property - uportal-ear.artifact - The full path to the uportal-ear EAR
| path - uportal-ear.classpath - The uportal-ear classpath not including the uportal-ear EAR
+-->
<macrodef name="uportal-ear-macro">
<element name="ear-sub-tasks" optional="false" implicit="true" />

<sequential>
<uportal-war-macro>
<uportal-portlets-overlay-macro>
<fileset id="uportal-war-artifacts" file="${uportal-war.artifact}" />

<maven-artifact-macro project-name="uportal-ear" project-path="${uportal-ear.dir}" checkfilesid="uportal-war-artifacts">
<!--
| Execute the ear-sub-tasks
+-->
<ear-sub-tasks />
</maven-artifact-macro>
</uportal-portlets-overlay-macro>
</uportal-war-macro>
</sequential>
</macrodef>

<!--
| Utility target for executing a maven with some number (up to 10) of goals. The
| target should automaticly work on all OSs as long as 'mvn' is on the path.
+-->
<target name="mvn">
<property name="goal" value="-Djasig.ignore" />
<property name="goal1" value="-Djasig.ignore" />
<property name="goal2" value="-Djasig.ignore" />
<property name="goal3" value="-Djasig.ignore" />
<property name="goal4" value="-Djasig.ignore" />
<property name="goal5" value="-Djasig.ignore" />
<property name="goal6" value="-Djasig.ignore" />
<property name="goal7" value="-Djasig.ignore" />
<property name="goal8" value="-Djasig.ignore" />
<property name="goal9" value="-Djasig.ignore" />

<condition property="test.skip" value="-Dmaven.test.skip=true">
<isset property="maven.test.skip"/>
</condition>
<property name="test.skip" value="-Dmaven.test.skip=false" />

<condition property="offline" value="-o">
<isset property="maven.offline"/>
</condition>
<property name="offline" value="-Djasig.ignore" />

<artifact:mvn pom="${pomDir}/pom.xml" failonerror="true" fork="true" mavenHome="${maven.home}" maxmemory="512m">
<arg value="-s${maven.settings}" />
<arg value="${test.skip}" />
<arg value="${offline}" />
<arg value="${goal}" />
<arg value="${goal1}" />
<arg value="${goal2}" />
<arg value="${goal3}" />
<arg value="${goal4}" />
<arg value="${goal5}" />
<arg value="${goal6}" />
<arg value="${goal7}" />
<arg value="${goal8}" />
<arg value="${goal9}" />
</artifact:mvn>
</target>
</project>



At first it all seems to run without any problems and is running and doing its installs and Builds Successfully, then however, I get the message above.


I apologies, I am new to this, and am encountering a 'Build Failed' message but am not sure what i'm doing wrong,

Please let me know if you require any further information.

Any help would be much appreciated.


Thanks in advance
 
I agree. Here's the link: http://aspose.com/file-tools
 
subject: uPortal 3.2.4 Build Failed
 
Similar Threads
ant exception
Converting Jrxml to pdf
WSDP2.0 pack example
Ant list -- Build Failed
Path not working