Fix VMS installation - deassign the same logical names that were defined
[openssl.git] / appveyor.yml
index 9c896fc810f228bd782301a73a7a51462cb6d834..9bb6f04e0a44cb0df6c81e4bc373fb61f7cc69ac 100644 (file)
@@ -1,3 +1,6 @@
+image:
+    - Visual Studio 2017
+
 platform:
     - x64
     - x86
@@ -5,64 +8,75 @@ platform:
 environment:
     fast_finish: true
     matrix:
-        - VSVER: 14
+        - VSVER: 15
 
 configuration:
     - shared
-    - plain
+    - minimal
+
+for:
+    -
+        branches:
+            only:
+                - master
+        configuration:
+            - shared
+            - plain
+            - minimal
 
 before_build:
+    - ps: >-
+        Install-Module VSSetup -Scope CurrentUser
+    - ps: >-
+        Get-VSSetupInstance -All
     - ps: >-
         If ($env:Platform -Match "x86") {
             $env:VCVARS_PLATFORM="x86"
-            $env:TARGET="VC-WIN32 no-asm"
+            $env:TARGET="VC-WIN32 no-asm --strict-warnings"
         } Else {
             $env:VCVARS_PLATFORM="amd64"
             $env:TARGET="VC-WIN64A-masm"
         }
     - ps: >-
         If ($env:Configuration -Match "shared") {
-            $env:SHARED=""
+            $env:CONFIG_OPTS="enable-fips"
+        } ElseIf ($env:Configuration -Match "minimal") {
+            $env:CONFIG_OPTS="no-bulk no-asm -DOPENSSL_SMALL_FOOTPRINT"
         } Else {
-            $env:SHARED="no-shared"
+            $env:CONFIG_OPTS="no-fips no-shared"
         }
-    - ps: $env:VSCOMNTOOLS=(Get-Content ("env:VS" + "$env:VSVER" + "0COMNTOOLS"))
-    - call "%VSCOMNTOOLS%\..\..\VC\vcvarsall.bat" %VCVARS_PLATFORM%
+    - call "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvarsall.bat" %VCVARS_PLATFORM%
     - mkdir _build
     - cd _build
-    - perl ..\Configure %TARGET% %SHARED%
+    - perl ..\Configure %TARGET% no-makedepend %CONFIG_OPTS%
+    - perl configdata.pm --dump
     - cd ..
     - ps: >-
-        if (-not $env:APPVEYOR_PULL_REQUEST_NUMBER -or (&git log -2 | Select-String "\[extended tests\]") ) {
-            $env:EXTENDED_TESTS="yes"
+        If ($env:BUILDONLY -or $env:MAKEVERBOSE) {
+            $env:NMAKE="nmake"
+        } Else {
+            $env:NMAKE="nmake /S"
         }
+    - ps: >-
+        gci env:* | sort-object name
 
 build_script:
-    - ps: >-
-        If ($env:Configuration -Match "shared" -or $env:EXTENDED_TESTS) {
-            cd _build
-            &nmake
-            cd ..
-        }
+    - cd _build
+    - "%NMAKE% build_all_generated"
+    - "%NMAKE% PERL=no-perl"
+    - cd ..
 
 test_script:
+    - cd _build
+    - ps: >-
+        if ($env:Configuration -Match "plain") {
+            cmd /c "%NMAKE% test VERBOSE_FAILURE=yes 2>&1"
+        } Else {
+            cmd /c "%NMAKE% test VERBOSE_FAILURE=yes TESTS=-test_fuzz 2>&1"
+        }
     - ps: >-
-        If ($env:Configuration -Match "shared" -or $env:EXTENDED_TESTS) {
-            cd _build
-            if ($env:EXTENDED_TESTS) {
-                &nmake test V=1
-                mkdir ..\_install
-                &nmake install install_docs DESTDIR=..\_install
-            } Else {
-                &nmake test V=1 TESTS=-test_fuzz
-            }
-            cd ..
+        if ($env:Configuration -Match "shared") {
+            mkdir ..\_install
+            cmd /c "%NMAKE% install DESTDIR=..\_install 2>&1"
         }
-
-notifications:
-    - provider: Email
-      to:
-          - openssl-commits@openssl.org
-      on_build_success: false
-      on_build_failure: true
-      on_build_status_changed: true
+    - cd ..