summaryrefslogtreecommitdiffstats
path: root/Tools/msi/uploadrelease.proj
diff options
context:
space:
mode:
authorSteve Dower <steve.dower@microsoft.com>2017-02-23 22:11:36 (GMT)
committerGitHub <noreply@github.com>2017-02-23 22:11:36 (GMT)
commit1aceb024172ea3d6f9dd6e90f4fbe63ea1fb054e (patch)
tree1cf5a4dbe8f40ee319a768d336c4e009e0c6b52b /Tools/msi/uploadrelease.proj
parent4c78c527d215c37472145152cb0e95f196cdddc9 (diff)
downloadcpython-1aceb024172ea3d6f9dd6e90f4fbe63ea1fb054e.zip
cpython-1aceb024172ea3d6f9dd6e90f4fbe63ea1fb054e.tar.gz
cpython-1aceb024172ea3d6f9dd6e90f4fbe63ea1fb054e.tar.bz2
bpo-29624: Adds purge step and layout test after uploading files. (#258)
Diffstat (limited to 'Tools/msi/uploadrelease.proj')
-rw-r--r--Tools/msi/uploadrelease.proj32
1 files changed, 31 insertions, 1 deletions
diff --git a/Tools/msi/uploadrelease.proj b/Tools/msi/uploadrelease.proj
index 0d472de..305e84f 100644
--- a/Tools/msi/uploadrelease.proj
+++ b/Tools/msi/uploadrelease.proj
@@ -9,6 +9,7 @@
<DownloadUrlBase Condition="'$(DownloadUrlBase)' == ''">/srv/www.python.org/ftp/python</DownloadUrlBase>
<IncludeDoc Condition="'$(IncludeDoc)' == ''">true</IncludeDoc>
<DryRun Condition="'$(DryRun)' == ''">false</DryRun>
+ <Purge Condition="'$(Purge)' == ''">false</Purge>
</PropertyGroup>
<Import Project="msi.props" />
@@ -64,7 +65,36 @@ echo.
echo." />
</Target>
- <Target Name="Upload" DependsOnTargets="_ValidateProperties;_RunGpg;_PrintNames;_Upload" />
+ <Target Name="_Purge" Condition="$(Purge) and !$(DryRun)">
+ <Error Condition="!Exists('$(PythonExe)')" Text="No Python executable available at $(PythonExe)" />
+ <Exec Command="&quot;$(PythonExe)&quot; purge.py $(PythonVersion)" />
+ </Target>
+
+ <Target Name="_TestLayout">
+ <ItemGroup>
+ <WebInstaller Include="$(OutputPath)\*-webinstall.exe" />
+ <WebInstaller>
+ <SourceDir>$(TEMP)\%(Filename)_source</SourceDir>
+ <SourceExe>$(TEMP)\%(Filename)_source\%(Filename)%(Extension)</SourceExe>
+ <LayoutDir>$(TEMP)\%(Filename)_layout</LayoutDir>
+ <LogDir>$(OutputPath)\%(Filename)_layoutlog</LogDir>
+ <LogFile>$(OutputPath)\%(Filename)_layoutlog\%(Filename).log</LogFile>
+ </WebInstaller>
+ </ItemGroup>
+ <RemoveDir Directories="%(WebInstaller.SourceDir)" Condition="Exists('%(WebInstaller.SourceDir)')" />
+ <RemoveDir Directories="%(WebInstaller.LayoutDir)" Condition="Exists('%(WebInstaller.LayoutDir)')" />
+ <RemoveDir Directories="%(WebInstaller.LogDir)" Condition="Exists('%(WebInstaller.LogDir)')" />
+ <MakeDir Directories="%(WebInstaller.SourceDir)" />
+ <Copy SourceFiles="@(WebInstaller)" DestinationFiles="%(WebInstaller.SourceExe)" />
+ <Exec Command="start &quot;Install test&quot; /wait &quot;%(WebInstaller.SourceExe)&quot; /layout &quot;%(WebInstaller.LayoutDir)&quot; /passive /log &quot;%(WebInstaller.LogFile)&quot;"
+ IgnoreExitCode="false" />
+ <RemoveDir Directories="%(WebInstaller.LayoutDir)" />
+ <RemoveDir Directories="%(WebInstaller.SourceDir)" />
+ <RemoveDir Directories="%(WebInstaller.LogDir)" />
+ </Target>
+
+ <Target Name="Upload" DependsOnTargets="_ValidateProperties;_RunGpg;_PrintNames;_Upload;_Purge" />
+ <Target Name="Test" DependsOnTargets="_TestLayout" />
<Target Name="ShowHashes">
<ItemGroup>