From ba35159444b4e29e6cdec5832c2ef3e1afc9bb2a Mon Sep 17 00:00:00 2001 From: Mann mit Hut Date: Sun, 12 Jan 2025 21:05:17 +0100 Subject: [PATCH] Add more information to the generated GitHub build matrix There are now two more fields available in each entry of the build matrix: `oldest` and `newest`. Both fields are boolean values and indicate whether the GHC version of the matrix entry is the newest version or the oldest version respectively that was found in the tested-with stanza of the Cabal file. --- app/Main.hs | 21 ++++++++++++++++++--- src/GetTested/Types.hs | 2 ++ 2 files changed, 20 insertions(+), 3 deletions(-) diff --git a/app/Main.hs b/app/Main.hs index c51133c..fb5b659 100644 --- a/app/Main.hs +++ b/app/Main.hs @@ -24,7 +24,7 @@ import System.Exit import GetTested.CLI.Types import GetTested.Extract import GetTested.Types -import Paths_get_tested (version) +import Paths_get_tested qualified main :: IO () main = do @@ -57,7 +57,7 @@ parseOptions = <*> optional (strOption (long "windows-version" <> metavar "VERSION" <> help "Enable the Windows runner with the selected version")) <*> switch (long "newest" <> help "Enable only the newest GHC version found in the cabal file") <*> switch (long "oldest" <> help "Enable only the oldest GHC version found in the cabal file") - <**> simpleVersioner (showVersion version) + <**> simpleVersioner (showVersion Paths_get_tested.version) runOptions :: Options -> Eff [Console, FileSystem, Error ProcessingError, IOE] ByteString runOptions options = do @@ -70,10 +70,25 @@ runOptions options = do processOSFlag MacOS options.macosFlag options.macosVersion <> processOSFlag Ubuntu options.ubuntuFlag options.ubuntuVersion <> processOSFlag Windows options.windowsFlag options.windowsVersion + isOldestCompiler = + if Vector.null selectedCompilers + then const False + else \version -> version == Vector.minimum selectedCompilers + isNewestCompiler = + if Vector.null selectedCompilers + then const False + else \version -> version == Vector.maximum selectedCompilers + makePlatformAndVersion os ghc = + PlatformAndVersion + { os + , ghc + , oldest = isOldestCompiler ghc + , newest = isNewestCompiler ghc + } if null filteredList then pure $ Aeson.encode selectedCompilers else do - let include = PlatformAndVersion <$> filteredList <*> selectedCompilers + let include = makePlatformAndVersion <$> filteredList <*> selectedCompilers pure $ "matrix=" <> Aeson.encode (ActionMatrix include) withInfo :: Parser a -> String -> ParserInfo a diff --git a/src/GetTested/Types.hs b/src/GetTested/Types.hs index ad0e1fb..1762702 100644 --- a/src/GetTested/Types.hs +++ b/src/GetTested/Types.hs @@ -66,6 +66,8 @@ data ActionMatrix = ActionMatrix data PlatformAndVersion = PlatformAndVersion { os :: Text , ghc :: Version + , oldest :: Bool + , newest :: Bool } deriving stock (Eq, Ord, Generic) deriving anyclass (ToJSON)