From 79ce5672959de6be90b3e50b84905149d00cccc2 Mon Sep 17 00:00:00 2001 From: Tristan Cacqueray Date: Tue, 9 Jan 2024 16:34:09 +0000 Subject: [PATCH] index: change the groups to optional for migration purpose When deploying the new schema, the existing documents does not have a groups attribute set, so this change reflect that to the data type. --- src/Monocle/Backend/Documents.hs | 4 ++-- src/Monocle/Backend/Index.hs | 2 +- src/Monocle/Backend/Janitor.hs | 2 +- src/Monocle/Backend/Test.hs | 6 +++--- 4 files changed, 7 insertions(+), 7 deletions(-) diff --git a/src/Monocle/Backend/Documents.hs b/src/Monocle/Backend/Documents.hs index cb0e2b86e..393f7022c 100644 --- a/src/Monocle/Backend/Documents.hs +++ b/src/Monocle/Backend/Documents.hs @@ -36,7 +36,7 @@ import Monocle.Protob.Search qualified as SearchPB data Author = Author { authorMuid :: LText , authorUid :: LText - , authorGroups :: [LText] + , authorGroups :: Maybe [LText] } deriving (Show, Eq, Generic) @@ -51,7 +51,7 @@ instance From ChangePB.Ident Author where Author { authorMuid = identMuid , authorUid = identUid - , authorGroups = toList identGroups + , authorGroups = Just $ toList identGroups } fromMaybeIdent :: Maybe ChangePB.Ident -> Author diff --git a/src/Monocle/Backend/Index.hs b/src/Monocle/Backend/Index.hs index 238c3ccd8..a0af23072 100644 --- a/src/Monocle/Backend/Index.hs +++ b/src/Monocle/Backend/Index.hs @@ -502,7 +502,7 @@ toAuthor (Just ChangePB.Ident {..}) = Monocle.Backend.Documents.Author { authorMuid = identMuid , authorUid = identUid - , authorGroups = toList identGroups + , authorGroups = Just $ toList identGroups } toAuthor Nothing = Monocle.Backend.Documents.Author diff --git a/src/Monocle/Backend/Janitor.hs b/src/Monocle/Backend/Janitor.hs index 4cd4c3257..52994f3df 100644 --- a/src/Monocle/Backend/Janitor.hs +++ b/src/Monocle/Backend/Janitor.hs @@ -28,7 +28,7 @@ import Streaming.Prelude qualified as Streaming updateAuthor :: Config.Index -> D.Author -> D.Author updateAuthor index author@D.Author {..} = case getIdent of - Just (identMuid, identGroups) -> D.Author (from identMuid) authorUid (from <$> identGroups) + Just (identMuid, identGroups) -> D.Author (from identMuid) authorUid (Just $ from <$> identGroups) Nothing | newMuid /= from authorMuid -> D.Author (from newMuid) authorUid authorGroups | otherwise -> author diff --git a/src/Monocle/Backend/Test.hs b/src/Monocle/Backend/Test.hs index 1b8598684..0fca8093e 100644 --- a/src/Monocle/Backend/Test.hs +++ b/src/Monocle/Backend/Test.hs @@ -237,7 +237,7 @@ testIndexChanges = withTenant doTest , echangeTitle = title , echangeRepositoryFullname = "fakerepo" , echangeUrl = "https://fakehost/change/" <> show number - , echangeAuthor = Author "John" "John" ["dev", "core"] + , echangeAuthor = Author "John" "John" (Just ["dev", "core"]) } testIndexEvents :: Assertion @@ -609,7 +609,7 @@ testJanitorUpdateIdents = do , idents = Just [Config.Ident ["github.com/john"] (Just ["dev", "core"]) "John Doe"] , search_aliases = Nothing } - expectedAuthor = Author "John Doe" "github.com/john" ["dev", "core"] + expectedAuthor = Author "John Doe" "github.com/john" (Just ["dev", "core"]) doUpdateIndentOnEventsTest :: Eff [MonoQuery, ElasticEffect, LoggerEffect, IOE] () doUpdateIndentOnEventsTest = E.runFailIO $ dieOnEsError do @@ -623,7 +623,7 @@ testJanitorUpdateIdents = do evt2' <- I.getChangeEventById $ I.getEventDocId evt2 assertEqual' "Ensure event not changed" evt2' $ Just evt2 where - evt1 = mkEventWithAuthor "e1" (Author "john" "github.com/john" ["not-core"]) + evt1 = mkEventWithAuthor "e1" (Author "john" "github.com/john" (Just ["not-core"])) evt2 = mkEventWithAuthor "e2" (Author "paul" "github.com/paul" mempty) mkEventWithAuthor :: -- eventId