Add GHC 9.6 to CI and fix tests (#193)
Tests needing fixing for recent minio Also: - set minimum tested version to 8.10 - remove building with cabal 3.6 - update stack.yaml to add crypton-connection Update live server test env var handling
This commit is contained in:
parent
34a186ed33
commit
78a27b44bf
46
.github/workflows/ci.yml
vendored
46
.github/workflows/ci.yml
vendored
@ -24,22 +24,22 @@ jobs:
|
|||||||
ormolu:
|
ormolu:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v4
|
||||||
- uses: haskell-actions/run-ormolu@v12
|
- uses: haskell-actions/run-ormolu@v15
|
||||||
with:
|
with:
|
||||||
version: "0.5.0.1"
|
version: "0.5.0.1"
|
||||||
|
|
||||||
hlint:
|
hlint:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: 'Set up HLint'
|
- name: "Set up HLint"
|
||||||
uses: haskell/actions/hlint-setup@v2
|
uses: haskell/actions/hlint-setup@v2
|
||||||
with:
|
with:
|
||||||
version: '3.5'
|
version: "3.5"
|
||||||
|
|
||||||
- name: 'Run HLint'
|
- name: "Run HLint"
|
||||||
uses: haskell/actions/hlint-run@v2
|
uses: haskell/actions/hlint-run@v2
|
||||||
with:
|
with:
|
||||||
path: '["src/", "test/", "examples"]'
|
path: '["src/", "test/", "examples"]'
|
||||||
@ -52,21 +52,20 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
os: [ubuntu-latest, windows-latest] # Removed macos-latest due to cert issues.
|
os: [ubuntu-latest, windows-latest] # Removed macos-latest due to cert issues.
|
||||||
cabal: ["3.6", "3.8", "latest"]
|
cabal: ["3.8", "latest"]
|
||||||
ghc:
|
ghc:
|
||||||
|
- "9.6"
|
||||||
- "9.4"
|
- "9.4"
|
||||||
- "9.2"
|
- "9.2"
|
||||||
- "9.0"
|
- "9.0"
|
||||||
- "8.10"
|
- "8.10"
|
||||||
- "8.8"
|
# exclude:
|
||||||
- "8.6"
|
# - os: windows-latest
|
||||||
exclude:
|
# ghc: "9.4"
|
||||||
- os: windows-latest
|
# cabal: "3.6"
|
||||||
ghc: "9.4"
|
|
||||||
cabal: "3.6"
|
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v4
|
||||||
if: github.event.action == 'opened' || github.event.action == 'synchronize' || github.event.ref == 'refs/heads/master'
|
if: github.event.action == 'opened' || github.event.action == 'synchronize' || github.event.ref == 'refs/heads/master'
|
||||||
|
|
||||||
- uses: haskell/actions/setup@v2
|
- uses: haskell/actions/setup@v2
|
||||||
@ -151,19 +150,21 @@ jobs:
|
|||||||
ghc:
|
ghc:
|
||||||
- "8.10.7"
|
- "8.10.7"
|
||||||
- "9.0.2"
|
- "9.0.2"
|
||||||
- "9.2.4"
|
- "9.2.8"
|
||||||
|
- "9.4.8"
|
||||||
|
- "9.6.5"
|
||||||
os: [ubuntu-latest]
|
os: [ubuntu-latest]
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v4
|
||||||
if: github.event.action == 'opened' || github.event.action == 'synchronize' || github.event.ref == 'refs/heads/master'
|
if: github.event.action == 'opened' || github.event.action == 'synchronize' || github.event.ref == 'refs/heads/master'
|
||||||
|
|
||||||
- uses: haskell/actions/setup@v2
|
- name: Install Haskell Stack
|
||||||
name: Setup Haskell Stack
|
run: |
|
||||||
with:
|
if ! which stack
|
||||||
enable-stack: true
|
then
|
||||||
ghc-version: ${{ matrix.ghc }}
|
curl -sSL https://get.haskellstack.org/ | sh
|
||||||
stack-version: 'latest'
|
fi
|
||||||
|
|
||||||
- uses: actions/cache@v3
|
- uses: actions/cache@v3
|
||||||
name: Cache ~/.stack
|
name: Cache ~/.stack
|
||||||
@ -182,6 +183,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: |
|
run: |
|
||||||
|
stack --version
|
||||||
stack build --system-ghc --test --bench --no-run-tests --no-run-benchmarks --only-dependencies
|
stack build --system-ghc --test --bench --no-run-tests --no-run-benchmarks --only-dependencies
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
|
|||||||
@ -22,12 +22,11 @@ extra-doc-files:
|
|||||||
extra-source-files:
|
extra-source-files:
|
||||||
examples/*.hs
|
examples/*.hs
|
||||||
stack.yaml
|
stack.yaml
|
||||||
tested-with: GHC == 8.6.5
|
tested-with: GHC == 8.10.7
|
||||||
, GHC == 8.8.4
|
|
||||||
, GHC == 8.10.7
|
|
||||||
, GHC == 9.0.2
|
, GHC == 9.0.2
|
||||||
, GHC == 9.2.7
|
, GHC == 9.2.8
|
||||||
, GHC == 9.4.5
|
, GHC == 9.4.8
|
||||||
|
, GHC == 9.6.5
|
||||||
|
|
||||||
source-repository head
|
source-repository head
|
||||||
type: git
|
type: git
|
||||||
|
|||||||
@ -15,7 +15,7 @@
|
|||||||
# resolver:
|
# resolver:
|
||||||
# name: custom-snapshot
|
# name: custom-snapshot
|
||||||
# location: "./custom-snapshot.yaml"
|
# location: "./custom-snapshot.yaml"
|
||||||
resolver: lts-19.7
|
resolver: lts-22.19
|
||||||
|
|
||||||
# User packages to be built.
|
# User packages to be built.
|
||||||
# Various formats can be used as shown in the example below.
|
# Various formats can be used as shown in the example below.
|
||||||
@ -36,17 +36,17 @@ resolver: lts-19.7
|
|||||||
# non-dependency (i.e. a user package), and its test suites and benchmarks
|
# non-dependency (i.e. a user package), and its test suites and benchmarks
|
||||||
# will not be run. This is useful for tweaking upstream packages.
|
# will not be run. This is useful for tweaking upstream packages.
|
||||||
packages:
|
packages:
|
||||||
- '.'
|
- "."
|
||||||
# Dependency packages to be pulled from upstream that are not in the resolver
|
# Dependency packages to be pulled from upstream that are not in the resolver
|
||||||
# (e.g., acme-missiles-0.3)
|
# (e.g., acme-missiles-0.3)
|
||||||
extra-deps: []
|
extra-deps:
|
||||||
|
- crypton-connection-0.3.2
|
||||||
|
|
||||||
# Override default flag values for local packages and extra-deps
|
# Override default flag values for local packages and extra-deps
|
||||||
flags: {}
|
flags: {}
|
||||||
|
|
||||||
# Extra package databases containing global packages
|
# Extra package databases containing global packages
|
||||||
extra-package-dbs: []
|
extra-package-dbs: []
|
||||||
|
|
||||||
# Control whether we use the GHC we find on the path
|
# Control whether we use the GHC we find on the path
|
||||||
# system-ghc: true
|
# system-ghc: true
|
||||||
#
|
#
|
||||||
|
|||||||
@ -3,10 +3,17 @@
|
|||||||
# For more information, please see the documentation at:
|
# For more information, please see the documentation at:
|
||||||
# https://docs.haskellstack.org/en/stable/lock_files
|
# https://docs.haskellstack.org/en/stable/lock_files
|
||||||
|
|
||||||
packages: []
|
packages:
|
||||||
|
- completed:
|
||||||
|
hackage: crypton-connection-0.3.2@sha256:c7937edc25ab022bcf167703f2ec5ab73b62908e545bb587d2aa42b33cd6f6cc,1581
|
||||||
|
pantry-tree:
|
||||||
|
sha256: f986ad29b008cbe5732606e9cde1897191c486a2f1f169a4cb75fd915bce397c
|
||||||
|
size: 394
|
||||||
|
original:
|
||||||
|
hackage: crypton-connection-0.3.2
|
||||||
snapshots:
|
snapshots:
|
||||||
- completed:
|
- completed:
|
||||||
size: 618884
|
sha256: e5cac927cf7ccbd52aa41476baa68b88c564ee6ddc3bc573dbf4210069287fe7
|
||||||
url: https://raw.githubusercontent.com/commercialhaskell/stackage-snapshots/master/lts/19/7.yaml
|
size: 713340
|
||||||
sha256: 57d4ce67cc097fea2058446927987bc1f7408890e3a6df0da74e5e318f051c20
|
url: https://raw.githubusercontent.com/commercialhaskell/stackage-snapshots/master/lts/22/19.yaml
|
||||||
original: lts-19.7
|
original: lts-22.19
|
||||||
|
|||||||
@ -49,6 +49,51 @@ main = defaultMain tests
|
|||||||
tests :: TestTree
|
tests :: TestTree
|
||||||
tests = testGroup "Tests" [liveServerUnitTests]
|
tests = testGroup "Tests" [liveServerUnitTests]
|
||||||
|
|
||||||
|
lookupTestEnv :: IO (Maybe ConnectInfo, (AccessKey, SecretKey))
|
||||||
|
lookupTestEnv = do
|
||||||
|
val <- Env.lookupEnv "MINIO_LOCAL"
|
||||||
|
secure <- Env.lookupEnv "MINIO_SECURE"
|
||||||
|
let localServerMaybe = case (val, secure) of
|
||||||
|
(Just _, Just _) -> Just "https://localhost:9000"
|
||||||
|
(Just _, Nothing) -> Just "http://localhost:9000"
|
||||||
|
_ -> Nothing
|
||||||
|
accessKeyE <- Env.lookupEnv "MINIO_ACCESS_KEY"
|
||||||
|
let accessKey = maybe "minioadmin" fromString accessKeyE
|
||||||
|
secretKeyE <- Env.lookupEnv "MINIO_SECRET_KEY"
|
||||||
|
let secretKey = maybe "minioadmin" fromString secretKeyE
|
||||||
|
return (localServerMaybe, (accessKey, secretKey))
|
||||||
|
|
||||||
|
loadTestServerConnInfo :: IO ConnectInfo
|
||||||
|
loadTestServerConnInfo = do
|
||||||
|
(localServerMaybe, (ak, sk)) <- lookupTestEnv
|
||||||
|
return $ case localServerMaybe of
|
||||||
|
Just localServer -> do
|
||||||
|
setCreds (CredentialValue ak sk mempty) localServer
|
||||||
|
_ -> minioPlayCI
|
||||||
|
|
||||||
|
loadTestServerConnInfoSTS :: IO ConnectInfo
|
||||||
|
loadTestServerConnInfoSTS = do
|
||||||
|
(localServerMaybe, (ak, sk)) <- lookupTestEnv
|
||||||
|
case localServerMaybe of
|
||||||
|
Just localServer -> do
|
||||||
|
let creds = CredentialValue ak sk mempty
|
||||||
|
assumeRole =
|
||||||
|
STSAssumeRole
|
||||||
|
{ sarCredentials = creds,
|
||||||
|
sarOptions = defaultSTSAssumeRoleOptions
|
||||||
|
}
|
||||||
|
setSTSCredential assumeRole localServer
|
||||||
|
Nothing -> do
|
||||||
|
let creds = case connectCreds minioPlayCI of
|
||||||
|
CredsStatic c -> c
|
||||||
|
_ -> error "unexpected play creds"
|
||||||
|
assumeRole =
|
||||||
|
STSAssumeRole
|
||||||
|
{ sarCredentials = creds,
|
||||||
|
sarOptions = defaultSTSAssumeRoleOptions
|
||||||
|
}
|
||||||
|
setSTSCredential assumeRole minioPlayCI
|
||||||
|
|
||||||
-- conduit that generates random binary stream of given length
|
-- conduit that generates random binary stream of given length
|
||||||
randomDataSrc :: (MonadIO m) => Int64 -> C.ConduitM () ByteString m ()
|
randomDataSrc :: (MonadIO m) => Int64 -> C.ConduitM () ByteString m ()
|
||||||
randomDataSrc = genBS
|
randomDataSrc = genBS
|
||||||
@ -76,34 +121,24 @@ mkRandFile size = do
|
|||||||
funTestBucketPrefix :: Text
|
funTestBucketPrefix :: Text
|
||||||
funTestBucketPrefix = "miniohstest-"
|
funTestBucketPrefix = "miniohstest-"
|
||||||
|
|
||||||
loadTestServerConnInfo :: IO ConnectInfo
|
funTestWithBucketNoSTS ::
|
||||||
loadTestServerConnInfo = do
|
TestName ->
|
||||||
val <- Env.lookupEnv "MINIO_LOCAL"
|
(([Char] -> Minio ()) -> Bucket -> Minio ()) ->
|
||||||
isSecure <- Env.lookupEnv "MINIO_SECURE"
|
TestTree
|
||||||
return $ case (val, isSecure) of
|
funTestWithBucketNoSTS t minioTest = testCaseSteps t $ \step -> do
|
||||||
(Just _, Just _) -> setCreds (CredentialValue "minio" "minio123" mempty) "https://localhost:9000"
|
-- generate a random name for the bucket
|
||||||
(Just _, Nothing) -> setCreds (CredentialValue "minio" "minio123" mempty) "http://localhost:9000"
|
bktSuffix <- liftIO $ generate $ Q.vectorOf 10 (Q.choose ('a', 'z'))
|
||||||
(Nothing, _) -> minioPlayCI
|
let b = T.concat [funTestBucketPrefix, T.pack bktSuffix]
|
||||||
|
liftStep = liftIO . step
|
||||||
loadTestServerConnInfoSTS :: IO ConnectInfo
|
connInfo <- loadTestServerConnInfo
|
||||||
loadTestServerConnInfoSTS = do
|
ret <- runMinio connInfo $ do
|
||||||
val <- Env.lookupEnv "MINIO_LOCAL"
|
liftStep $ "Creating bucket for test - " ++ t
|
||||||
isSecure <- Env.lookupEnv "MINIO_SECURE"
|
foundBucket <- bucketExists b
|
||||||
let cv = CredentialValue "minio" "minio123" mempty
|
liftIO $ foundBucket @?= False
|
||||||
assumeRole =
|
makeBucket b Nothing
|
||||||
STSAssumeRole
|
minioTest liftStep b
|
||||||
{ sarCredentials = cv,
|
deleteBucket b
|
||||||
sarOptions = defaultSTSAssumeRoleOptions
|
isRight ret @? ("Functional test " ++ t ++ " failed => " ++ show ret)
|
||||||
}
|
|
||||||
case (val, isSecure) of
|
|
||||||
(Just _, Just _) -> setSTSCredential assumeRole "https://localhost:9000"
|
|
||||||
(Just _, Nothing) -> setSTSCredential assumeRole "http://localhost:9000"
|
|
||||||
(Nothing, _) -> do
|
|
||||||
cv' <- case connectCreds minioPlayCI of
|
|
||||||
CredsStatic c -> return c
|
|
||||||
_ -> error "unexpected play creds"
|
|
||||||
let assumeRole' = assumeRole {sarCredentials = cv'}
|
|
||||||
setSTSCredential assumeRole' minioPlayCI
|
|
||||||
|
|
||||||
funTestWithBucket ::
|
funTestWithBucket ::
|
||||||
TestName ->
|
TestName ->
|
||||||
@ -603,7 +638,7 @@ presignedUrlFunTest = funTestWithBucket "presigned Url tests" $
|
|||||||
[]
|
[]
|
||||||
[]
|
[]
|
||||||
|
|
||||||
print putUrl
|
-- print putUrl
|
||||||
let size1 = 1000 :: Int64
|
let size1 = 1000 :: Int64
|
||||||
inputFile <- mkRandFile size1
|
inputFile <- mkRandFile size1
|
||||||
|
|
||||||
@ -692,7 +727,7 @@ presignedUrlFunTest = funTestWithBucket "presigned Url tests" $
|
|||||||
NC.httpLbs req mgr
|
NC.httpLbs req mgr
|
||||||
|
|
||||||
presignedPostPolicyFunTest :: TestTree
|
presignedPostPolicyFunTest :: TestTree
|
||||||
presignedPostPolicyFunTest = funTestWithBucket "Presigned Post Policy tests" $
|
presignedPostPolicyFunTest = funTestWithBucketNoSTS "Presigned Post Policy tests" $
|
||||||
\step bucket -> do
|
\step bucket -> do
|
||||||
step "presignedPostPolicy basic test"
|
step "presignedPostPolicy basic test"
|
||||||
now <- liftIO Time.getCurrentTime
|
now <- liftIO Time.getCurrentTime
|
||||||
@ -1222,9 +1257,10 @@ getNPutSSECTest =
|
|||||||
assumeRoleRequestTest :: TestTree
|
assumeRoleRequestTest :: TestTree
|
||||||
assumeRoleRequestTest = testCaseSteps "Assume Role STS API" $ \step -> do
|
assumeRoleRequestTest = testCaseSteps "Assume Role STS API" $ \step -> do
|
||||||
step "Load credentials"
|
step "Load credentials"
|
||||||
|
(_, (ak, sk)) <- lookupTestEnv
|
||||||
val <- Env.lookupEnv "MINIO_LOCAL"
|
val <- Env.lookupEnv "MINIO_LOCAL"
|
||||||
isSecure <- Env.lookupEnv "MINIO_SECURE"
|
isSecure <- Env.lookupEnv "MINIO_SECURE"
|
||||||
let localMinioCred = Just $ CredentialValue "minio" "minio123" mempty
|
let localMinioCred = Just $ CredentialValue ak sk mempty
|
||||||
playCreds =
|
playCreds =
|
||||||
case connectCreds minioPlayCI of
|
case connectCreds minioPlayCI of
|
||||||
CredsStatic c -> Just c
|
CredsStatic c -> Just c
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user