在我的开发计算机上,我安装了 VSeWSS 1.3 并配置了本地IIS 6,以便我可以构建我的SharePoint项目并部署 < strong>生成WSP 文件到本地计算机。 WSP文件由Packaging步骤生成,我可以在其他机器上成功安装。
现在我必须将我的项目迁移到我们的构建计算机,该计算机当前没有安装SharePoint,也没有为VSeWSS配置(没有VSeWSS Web服务端点)。 是否有办法自动构建WSP文件,而无需在构建计算机上配置IIS以与SharePoint和VSeWSS一起使用?
部分图书描述了使用 MakeCab.exe并定义DDF 文件的手动步骤,但我没有看到任何 DDF文件生成VSeWSS (是否可以在TEMP文件夹中生成,我可以用它来配置我的自动构建过程?)。
答案 0 :(得分:5)
我刚遇到同样的问题。我选择了另一种开发整个解决方案的工具:我发现WSPBuilder
更清洁,更少侵入。它也可以在命令行中使用,这对于构建文件非常有用。
我修改了Bil Simser创建的一些Nant脚本,以便编译和部署项目,并将代码从VSeWSS移动到WSPBuilder。它在我的机器或构建机器上就像一个魅力。
您可以在http://www.Codeplex.com找到WSPBuilder,这些目标需要nantContrib(在www.tigris.org上)才能正常工作。
以下是我正在使用的一些目标:
<target name="build" depends="compile">
<copy todir="${build.dir}\12\">
<fileset basedir="${sharepoint.dir}\12">
<include name="**/*"/>
</fileset>
</copy>
<copy
file="${sharepoint.dir}\solutionid.txt"
tofile="${build.dir}\solutionid.txt"
/>
<call target="buildsolutionfile" />
</target>
<target name="buildsolutionfile">
<exec program="${wspbuilder.exe}" workingdir="${build.dir}">
<arg value="-BuildDDF"/>
<arg value="${debug}"/>
<arg value="-Cleanup"/>
<arg value="false"/>
<arg value="-FolderDestination"/>
<arg value="${build.dir}"/>
<arg value="-Outputpath"/>
<arg value="${build.dir}"/>
<arg value="-TraceLevel"/>
<arg value="verbose"/>
</exec>
<copy
file="${build.dir}\${package.file}"
tofile="${solution.dir}\${package.file}"/>
</target>
<target name="addsolution">
<exec program="${stsadm.exe}" verbose="${verbose}">
<arg value="-o" />
<arg value="addsolution" />
<arg value="-filename" />
<arg value="${solution.dir}\${package.file}" />
</exec>
<call target="spwait" />
</target>
<target name="spwait" description="Waits for the timer job to complete.">
<exec program="${stsadm.exe}" verbose="${verbose}">
<arg value="-o" />
<arg value="execadmsvcjobs" />
</exec>
</target>
<target name="app.pool.reset" description="Resets Sharepoint's application pool.">
<iisapppool action="Restart" pool="${apppool}" server="${server}" />
</target>
<target name="deploysolution" depends="addsolution">
<exec program="${stsadm.exe}" workingdir="${build.dir}" verbose="${verbose}">
<arg value="-o" />
<arg value="deploysolution" />
<arg value="-name" />
<arg value="${package.file}" />
<arg value="-immediate" />
<arg value="-allowgacdeployment" />
<arg value="-allcontenturls" />
<arg value="-force" />
</exec>
<call target="spwait" />
<call target="app.pool.reset" />
</target>