Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
haskell-gargantext
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Julien Moutinho
haskell-gargantext
Commits
99e38af8
Verified
Commit
99e38af8
authored
Oct 27, 2023
by
Przemyslaw Kaminski
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[tests] refactoring of node story tests
parent
a42dca01
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
76 additions
and
95 deletions
+76
-95
Operations.hs
test/Test/Database/Operations.hs
+8
-8
NodeStory.hs
test/Test/Database/Operations/NodeStory.hs
+68
-87
No files found.
test/Test/Database/Operations.hs
View file @
99e38af8
...
@@ -75,14 +75,14 @@ nodeStoryTests = sequential $
...
@@ -75,14 +75,14 @@ nodeStoryTests = sequential $
around
setupDBAndCorpus
$
around
setupDBAndCorpus
$
describe
"Database - node story"
$
do
describe
"Database - node story"
$
do
describe
"Node story"
$
do
describe
"Node story"
$
do
it
"Can create a list"
createListTest
it
"
[#281]
Can create a list"
createListTest
it
"Can query node story"
queryNodeStoryTest
it
"
[#281]
Can query node story"
queryNodeStoryTest
it
"Can add new terms to node story"
insertNewTermsToNodeStoryTest
it
"
[#218]
Can add new terms to node story"
insertNewTermsToNodeStoryTest
it
"Can add new terms (with children) to node story"
insertNewTermsWithChildrenToNodeStoryTest
it
"
[#281]
Can add new terms (with children) to node story"
insertNewTermsWithChildrenToNodeStoryTest
it
"Fixes child terms to match parents' terms"
insertNodeStoryChildrenWithDifferentNgramsTypeThanParentTest
it
"
[#281]
Fixes child terms to match parents' terms"
insertNodeStoryChildrenWithDifferentNgramsTypeThanParentTest
it
"Can update node story when 'setListNgrams' is called"
setListNgramsUpdatesNodeStoryTest
it
"
[#281]
Can update node story when 'setListNgrams' is called"
setListNgramsUpdatesNodeStoryTest
it
"When 'setListNgrams' is called, childrens' parents are updated"
setListNgramsUpdatesNodeStoryWithChildrenTest
it
"
[#281]
When 'setListNgrams' is called, childrens' parents are updated"
setListNgramsUpdatesNodeStoryWithChildrenTest
it
"Correctly commits patches to node story - simple"
commitPatchSimpleTest
it
"
[#281]
Correctly commits patches to node story - simple"
commitPatchSimpleTest
where
where
setupDBAndCorpus
testsFunc
=
withTestDB
$
\
env
->
do
setupDBAndCorpus
testsFunc
=
withTestDB
$
\
env
->
do
setupEnvironment
env
setupEnvironment
env
...
...
test/Test/Database/Operations/NodeStory.hs
View file @
99e38af8
...
@@ -13,19 +13,19 @@ Portability : POSIX
...
@@ -13,19 +13,19 @@ Portability : POSIX
module
Test.Database.Operations.NodeStory
where
module
Test.Database.Operations.NodeStory
where
import
Control.Lens
((
.~
)
)
import
Control.Lens
((
^.
),
(
.~
),
_2
)
import
Control.Monad.Reader
import
Control.Monad.Reader
import
Data.Map.Strict
qualified
as
Map
import
Data.Map.Strict
qualified
as
Map
import
Data.Map.Strict.Patch
qualified
as
PM
import
Data.Map.Strict.Patch
qualified
as
PM
import
Data.Set
qualified
as
Set
import
Data.Set
qualified
as
Set
import
Database.PostgreSQL.Simple
qualified
as
PSQL
import
Database.PostgreSQL.Simple
qualified
as
PSQL
import
Database.PostgreSQL.Simple.SqlQQ
import
Database.PostgreSQL.Simple.SqlQQ
import
Gargantext.API.Ngrams
(
commitStatePatch
,
setListNgrams
,
saveNodeStoryImmediate
)
import
Gargantext.API.Ngrams
(
commitStatePatch
,
mSetFromList
,
setListNgrams
,
saveNodeStoryImmediate
)
import
Gargantext.API.Ngrams.Types
(
MSet
(
..
),
NgramsPatch
(
..
),
NgramsRepoElement
(
..
),
NgramsTerm
(
..
),
Versioned
(
..
),
mkNgramsTablePatch
,
nre_
lis
t
)
import
Gargantext.API.Ngrams.Types
(
MSet
(
..
),
NgramsPatch
(
..
),
NgramsRepoElement
(
..
),
NgramsTerm
(
..
),
Versioned
(
..
),
mkNgramsTablePatch
,
nre_
children
,
nre_list
,
nre_parent
,
nre_roo
t
)
import
Gargantext.API.Ngrams.Tools
(
getNodeStoryVar
)
import
Gargantext.API.Ngrams.Tools
(
getNodeStoryVar
)
import
Gargantext.Core.NodeStory
hiding
(
runPGSQuery
)
import
Gargantext.Core.NodeStory
hiding
(
runPGSQuery
)
import
Gargantext.Core.Types.Individu
import
Gargantext.Core.Types.Individu
import
Gargantext.Core.Types
(
ListType
(
..
))
import
Gargantext.Core.Types
(
ListType
(
..
)
,
ListId
,
NodeId
,
UserId
)
import
Gargantext.Database.Action.User
(
getUserId
)
import
Gargantext.Database.Action.User
(
getUserId
)
import
Gargantext.Database.Admin.Config
(
userMaster
)
import
Gargantext.Database.Admin.Config
(
userMaster
)
import
Gargantext.Database.Prelude
(
runPGSQuery
)
import
Gargantext.Database.Prelude
(
runPGSQuery
)
...
@@ -35,16 +35,13 @@ import Gargantext.Database.Query.Tree.Root
...
@@ -35,16 +35,13 @@ import Gargantext.Database.Query.Tree.Root
import
Gargantext.Database.Schema.Ngrams
(
NgramsType
(
..
))
import
Gargantext.Database.Schema.Ngrams
(
NgramsType
(
..
))
import
Gargantext.Database.Schema.Node
(
NodePoly
(
..
))
import
Gargantext.Database.Schema.Node
(
NodePoly
(
..
))
import
Gargantext.Prelude
import
Gargantext.Prelude
import
GHC.Conc
(
readTVar
)
import
GHC.Conc
(
TVar
,
readTVar
)
import
Test.Database.Types
import
Test.Database.Types
import
Test.Hspec.Expectations
import
Test.Hspec.Expectations
import
Test.Tasty.HUnit
import
Test.Tasty.HUnit
commonInitialization
::
TestMonad
(
Gargantext
.
Database
.
Admin
.
Types
.
Node
.
UserId
commonInitialization
::
TestMonad
(
UserId
,
NodeId
,
ListId
,
TVar
NodeListStory
)
,
Gargantext
.
Database
.
Admin
.
Types
.
Node
.
NodeId
,
Gargantext
.
Database
.
Admin
.
Types
.
Node
.
ListId
,
GHC
.
Conc
.
Sync
.
TVar
NodeListStory
)
commonInitialization
=
do
commonInitialization
=
do
let
user
=
UserName
userMaster
let
user
=
UserName
userMaster
parentId
<-
getRootId
user
parentId
<-
getRootId
user
...
@@ -60,6 +57,36 @@ commonInitialization = do
...
@@ -60,6 +57,36 @@ commonInitialization = do
pure
$
(
userId
,
corpusId
,
listId
,
v
)
pure
$
(
userId
,
corpusId
,
listId
,
v
)
initArchiveList
::
ArchiveList
initArchiveList
=
initArchive
simpleTerm
::
(
NgramsTerm
,
NgramsRepoElement
)
simpleTerm
=
(
NgramsTerm
"hello"
,
NgramsRepoElement
{
_nre_size
=
1
,
_nre_list
=
MapTerm
,
_nre_root
=
Nothing
,
_nre_parent
=
Nothing
,
_nre_children
=
MSet
Map
.
empty
}
)
simpleParentTerm'
::
NgramsTerm
simpleParentTerm'
=
fst
simpleTerm
simpleParentTerm
::
(
NgramsTerm
,
NgramsRepoElement
)
simpleParentTerm
=
(
simpleParentTerm'
,
simpleTerm
^.
_2
&
nre_children
.~
(
mSetFromList
[
simpleChildTerm'
])
)
simpleChildTerm'
::
NgramsTerm
simpleChildTerm'
=
NgramsTerm
"world"
simpleChildTerm
::
(
NgramsTerm
,
NgramsRepoElement
)
simpleChildTerm
=
(
simpleChildTerm'
,
simpleTerm
^.
_2
&
nre_parent
.~
Just
simpleParentTerm'
&
nre_root
.~
Just
simpleParentTerm'
)
-- tests start here
createListTest
::
TestEnv
->
Assertion
createListTest
::
TestEnv
->
Assertion
createListTest
env
=
do
createListTest
env
=
do
flip
runReaderT
env
$
runTestMonad
$
do
flip
runReaderT
env
$
runTestMonad
$
do
...
@@ -79,8 +106,7 @@ queryNodeStoryTest env = do
...
@@ -79,8 +106,7 @@ queryNodeStoryTest env = do
liftIO
$
do
liftIO
$
do
ns
<-
atomically
$
readTVar
v
ns
<-
atomically
$
readTVar
v
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
initArchiveList
)
(
initArchive
::
ArchiveList
))
insertNewTermsToNodeStoryTest
::
TestEnv
->
Assertion
insertNewTermsToNodeStoryTest
::
TestEnv
->
Assertion
...
@@ -88,22 +114,17 @@ insertNewTermsToNodeStoryTest env = do
...
@@ -88,22 +114,17 @@ insertNewTermsToNodeStoryTest env = do
flip
runReaderT
env
$
runTestMonad
$
do
flip
runReaderT
env
$
runTestMonad
$
do
(
_userId
,
_corpusId
,
listId
,
v
)
<-
commonInitialization
(
_userId
,
_corpusId
,
listId
,
v
)
<-
commonInitialization
let
nre
=
NgramsRepoElement
{
_nre_size
=
1
let
(
terms
,
nre
)
=
simpleTerm
,
_nre_list
=
MapTerm
let
nls
=
Map
.
singleton
terms
nre
,
_nre_root
=
Nothing
,
_nre_parent
=
Nothing
,
_nre_children
=
MSet
Map
.
empty
}
let
terms
=
"hello"
let
nls
=
Map
.
singleton
(
NgramsTerm
terms
)
nre
setListNgrams
listId
NgramsTerms
nls
setListNgrams
listId
NgramsTerms
nls
liftIO
$
do
liftIO
$
do
ns
<-
atomically
$
readTVar
v
ns
<-
atomically
$
readTVar
v
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
(
(
initArchive
::
ArchiveList
)
{
_a_state
=
Map
.
singleton
NgramsTerms
nls
}))
(
initArchiveList
{
_a_state
=
Map
.
singleton
NgramsTerms
nls
}))
-- check that the ngrams are in the DB as well
-- check that the ngrams are in the DB as well
ngramsMap
<-
selectNgramsId
[
terms
]
ngramsMap
<-
selectNgramsId
[
unNgramsTerm
terms
]
liftIO
$
(
snd
<$>
Map
.
toList
ngramsMap
)
`
shouldBe
`
[
terms
]
liftIO
$
(
snd
<$>
Map
.
toList
ngramsMap
)
`
shouldBe
`
[
unNgramsTerm
terms
]
-- Finally, check that node stories are inserted correctly
-- Finally, check that node stories are inserted correctly
dbTerms
<-
runPGSQuery
[
sql
|
dbTerms
<-
runPGSQuery
[
sql
|
...
@@ -112,7 +133,7 @@ insertNewTermsToNodeStoryTest env = do
...
@@ -112,7 +133,7 @@ insertNewTermsToNodeStoryTest env = do
JOIN node_stories ON ngrams.id = ngrams_id
JOIN node_stories ON ngrams.id = ngrams_id
WHERE node_id = ?
WHERE node_id = ?
|]
(
PSQL
.
Only
listId
)
|]
(
PSQL
.
Only
listId
)
liftIO
$
dbTerms
`
shouldBe
`
[
PSQL
.
Only
terms
]
liftIO
$
dbTerms
`
shouldBe
`
[
PSQL
.
Only
$
unNgramsTerm
terms
]
insertNewTermsWithChildrenToNodeStoryTest
::
TestEnv
->
Assertion
insertNewTermsWithChildrenToNodeStoryTest
::
TestEnv
->
Assertion
...
@@ -120,19 +141,9 @@ insertNewTermsWithChildrenToNodeStoryTest env = do
...
@@ -120,19 +141,9 @@ insertNewTermsWithChildrenToNodeStoryTest env = do
flip
runReaderT
env
$
runTestMonad
$
do
flip
runReaderT
env
$
runTestMonad
$
do
(
_userId
,
_corpusId
,
listId
,
v
)
<-
commonInitialization
(
_userId
,
_corpusId
,
listId
,
v
)
<-
commonInitialization
let
tParent
=
NgramsTerm
"hello"
let
(
tParent
,
nreParent
)
=
simpleParentTerm
let
tChild
=
NgramsTerm
"world"
let
(
tChild
,
nreChild
)
=
simpleChildTerm
let
terms
=
unNgramsTerm
<$>
[
tParent
,
tChild
]
let
terms
=
unNgramsTerm
<$>
[
tParent
,
tChild
]
let
nreParent
=
NgramsRepoElement
{
_nre_size
=
1
,
_nre_list
=
MapTerm
,
_nre_root
=
Nothing
,
_nre_parent
=
Nothing
,
_nre_children
=
MSet
$
Map
.
singleton
tChild
()
}
let
nreChild
=
NgramsRepoElement
{
_nre_size
=
1
,
_nre_list
=
MapTerm
,
_nre_root
=
Just
tParent
,
_nre_parent
=
Just
tParent
,
_nre_children
=
MSet
Map
.
empty
}
let
nls
=
Map
.
fromList
[(
tParent
,
nreParent
),
(
tChild
,
nreChild
)]
let
nls
=
Map
.
fromList
[(
tParent
,
nreParent
),
(
tChild
,
nreChild
)]
setListNgrams
listId
NgramsTerms
nls
setListNgrams
listId
NgramsTerms
nls
...
@@ -140,7 +151,7 @@ insertNewTermsWithChildrenToNodeStoryTest env = do
...
@@ -140,7 +151,7 @@ insertNewTermsWithChildrenToNodeStoryTest env = do
liftIO
$
do
liftIO
$
do
ns
<-
atomically
$
readTVar
v
ns
<-
atomically
$
readTVar
v
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
(
(
initArchive
::
ArchiveList
)
{
_a_state
=
Map
.
singleton
NgramsTerms
nls
}))
(
initArchiveList
{
_a_state
=
Map
.
singleton
NgramsTerms
nls
}))
-- `setListNgrams` calls saveNodeStory already so we should have
-- `setListNgrams` calls saveNodeStory already so we should have
-- the terms in the DB by now
-- the terms in the DB by now
...
@@ -169,30 +180,20 @@ insertNodeStoryChildrenWithDifferentNgramsTypeThanParentTest env = do
...
@@ -169,30 +180,20 @@ insertNodeStoryChildrenWithDifferentNgramsTypeThanParentTest env = do
flip
runReaderT
env
$
runTestMonad
$
do
flip
runReaderT
env
$
runTestMonad
$
do
(
_userId
,
_corpusId
,
listId
,
v
)
<-
commonInitialization
(
_userId
,
_corpusId
,
listId
,
v
)
<-
commonInitialization
let
tParent
=
NgramsTerm
"hello"
let
(
tParent
,
nreParent
)
=
simpleParentTerm
let
tChild
=
NgramsTerm
"world"
let
(
tChild
,
nreChildGoodType
)
=
simpleChildTerm
let
nreChildBrokenType
=
nreChildGoodType
&
nre_list
.~
MapTerm
let
terms
=
unNgramsTerm
<$>
[
tParent
,
tChild
]
let
terms
=
unNgramsTerm
<$>
[
tParent
,
tChild
]
let
nreParent
=
NgramsRepoElement
{
_nre_size
=
1
,
_nre_list
=
MapTerm
,
_nre_root
=
Nothing
,
_nre_parent
=
Nothing
,
_nre_children
=
MSet
$
Map
.
singleton
tChild
()
}
let
nreChild
=
NgramsRepoElement
{
_nre_size
=
1
,
_nre_list
=
CandidateTerm
,
_nre_root
=
Just
tParent
,
_nre_parent
=
Just
tParent
,
_nre_children
=
MSet
Map
.
empty
}
let
nreChildFixedType
=
nreChild
&
nre_list
.~
MapTerm
let
nls
=
Map
.
fromList
[(
tParent
,
nreParent
),
(
tChild
,
nreChild
)]
let
nls
=
Map
.
fromList
[(
tParent
,
nreParent
),
(
tChild
,
nreChild
BrokenType
)]
let
nlsWithChildFixed
=
Map
.
fromList
[(
tParent
,
nreParent
),
(
tChild
,
nreChild
Fixe
dType
)]
let
nlsWithChildFixed
=
Map
.
fromList
[(
tParent
,
nreParent
),
(
tChild
,
nreChild
Goo
dType
)]
setListNgrams
listId
NgramsTerms
nls
setListNgrams
listId
NgramsTerms
nls
liftIO
$
do
liftIO
$
do
ns
<-
atomically
$
readTVar
v
ns
<-
atomically
$
readTVar
v
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
(
(
initArchive
::
ArchiveList
)
{
_a_state
=
Map
.
singleton
NgramsTerms
nlsWithChildFixed
}))
(
initArchiveList
{
_a_state
=
Map
.
singleton
NgramsTerms
nlsWithChildFixed
}))
ngramsMap
<-
selectNgramsId
terms
ngramsMap
<-
selectNgramsId
terms
liftIO
$
(
snd
<$>
Map
.
toList
ngramsMap
)
`
shouldBe
`
terms
liftIO
$
(
snd
<$>
Map
.
toList
ngramsMap
)
`
shouldBe
`
terms
...
@@ -217,22 +218,17 @@ setListNgramsUpdatesNodeStoryTest env = do
...
@@ -217,22 +218,17 @@ setListNgramsUpdatesNodeStoryTest env = do
flip
runReaderT
env
$
runTestMonad
$
do
flip
runReaderT
env
$
runTestMonad
$
do
(
_userId
,
_corpusId
,
listId
,
v
)
<-
commonInitialization
(
_userId
,
_corpusId
,
listId
,
v
)
<-
commonInitialization
let
nre
=
NgramsRepoElement
{
_nre_size
=
1
let
(
terms
,
nre
)
=
simpleTerm
,
_nre_list
=
MapTerm
let
nls
=
Map
.
singleton
terms
nre
,
_nre_root
=
Nothing
,
_nre_parent
=
Nothing
,
_nre_children
=
MSet
Map
.
empty
}
let
terms
=
"HELLO"
let
nls
=
Map
.
singleton
(
NgramsTerm
terms
)
nre
setListNgrams
listId
NgramsTerms
nls
setListNgrams
listId
NgramsTerms
nls
liftIO
$
do
liftIO
$
do
ns
<-
atomically
$
readTVar
v
ns
<-
atomically
$
readTVar
v
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
(
(
initArchive
::
ArchiveList
)
{
_a_state
=
Map
.
singleton
NgramsTerms
nls
}))
(
initArchiveList
{
_a_state
=
Map
.
singleton
NgramsTerms
nls
}))
-- check that the ngrams are in the DB as well
-- check that the ngrams are in the DB as well
ngramsMap
<-
selectNgramsId
[
terms
]
ngramsMap
<-
selectNgramsId
[
unNgramsTerm
terms
]
liftIO
$
(
snd
<$>
Map
.
toList
ngramsMap
)
`
shouldBe
`
[
terms
]
liftIO
$
(
snd
<$>
Map
.
toList
ngramsMap
)
`
shouldBe
`
[
unNgramsTerm
terms
]
let
nre2
=
NgramsRepoElement
{
_nre_size
=
1
let
nre2
=
NgramsRepoElement
{
_nre_size
=
1
,
_nre_list
=
MapTerm
,
_nre_list
=
MapTerm
...
@@ -246,7 +242,7 @@ setListNgramsUpdatesNodeStoryTest env = do
...
@@ -246,7 +242,7 @@ setListNgramsUpdatesNodeStoryTest env = do
liftIO
$
do
liftIO
$
do
ns
<-
atomically
$
readTVar
v
ns
<-
atomically
$
readTVar
v
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
(
(
initArchive
::
ArchiveList
)
{
_a_state
=
Map
.
singleton
NgramsTerms
$
nls
<>
nls2
}))
(
initArchiveList
{
_a_state
=
Map
.
singleton
NgramsTerms
$
nls
<>
nls2
}))
setListNgramsUpdatesNodeStoryWithChildrenTest
::
TestEnv
->
Assertion
setListNgramsUpdatesNodeStoryWithChildrenTest
::
TestEnv
->
Assertion
...
@@ -254,25 +250,15 @@ setListNgramsUpdatesNodeStoryWithChildrenTest env = do
...
@@ -254,25 +250,15 @@ setListNgramsUpdatesNodeStoryWithChildrenTest env = do
flip
runReaderT
env
$
runTestMonad
$
do
flip
runReaderT
env
$
runTestMonad
$
do
(
_userId
,
_corpusId
,
listId
,
v
)
<-
commonInitialization
(
_userId
,
_corpusId
,
listId
,
v
)
<-
commonInitialization
let
tParent
=
NgramsTerm
"hello"
let
(
tChild
,
nreChild
)
=
simpleChildTerm
let
tChild
=
NgramsTerm
"world"
let
(
tParent
,
nreParent
)
=
simpleParentTerm
let
nreParent
=
NgramsRepoElement
{
_nre_size
=
1
,
_nre_list
=
MapTerm
,
_nre_root
=
Nothing
,
_nre_parent
=
Nothing
,
_nre_children
=
MSet
$
Map
.
singleton
tChild
()
}
let
nreChild
=
NgramsRepoElement
{
_nre_size
=
1
,
_nre_list
=
MapTerm
,
_nre_root
=
Just
tParent
,
_nre_parent
=
Just
tParent
,
_nre_children
=
MSet
Map
.
empty
}
let
nls
=
Map
.
fromList
[(
tParent
,
nreParent
),
(
tChild
,
nreChild
)]
let
nls
=
Map
.
fromList
[(
tParent
,
nreParent
),
(
tChild
,
nreChild
)]
setListNgrams
listId
NgramsTerms
nls
setListNgrams
listId
NgramsTerms
nls
liftIO
$
do
liftIO
$
do
ns
<-
atomically
$
readTVar
v
ns
<-
atomically
$
readTVar
v
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
(
(
initArchive
::
ArchiveList
)
{
_a_state
=
Map
.
singleton
NgramsTerms
nls
}))
(
initArchiveList
{
_a_state
=
Map
.
singleton
NgramsTerms
nls
}))
-- OK, now we substitute parent with no children, the parent of
-- OK, now we substitute parent with no children, the parent of
-- 'nreChild' should become Nothing
-- 'nreChild' should become Nothing
...
@@ -287,7 +273,7 @@ setListNgramsUpdatesNodeStoryWithChildrenTest env = do
...
@@ -287,7 +273,7 @@ setListNgramsUpdatesNodeStoryWithChildrenTest env = do
liftIO
$
do
liftIO
$
do
ns
<-
atomically
$
readTVar
v
ns
<-
atomically
$
readTVar
v
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
(
(
initArchive
::
ArchiveList
)
{
_a_state
=
Map
.
singleton
NgramsTerms
nlsNew
}))
(
initArchiveList
{
_a_state
=
Map
.
singleton
NgramsTerms
nlsNew
}))
commitPatchSimpleTest
::
TestEnv
->
Assertion
commitPatchSimpleTest
::
TestEnv
->
Assertion
...
@@ -299,14 +285,9 @@ commitPatchSimpleTest env = do
...
@@ -299,14 +285,9 @@ commitPatchSimpleTest env = do
liftIO
$
do
liftIO
$
do
ns
<-
atomically
$
readTVar
v
ns
<-
atomically
$
readTVar
v
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
((
initArchive
::
ArchiveList
)
{
_a_state
=
Map
.
empty
}))
(
initArchiveList
{
_a_state
=
Map
.
empty
}))
let
term
=
NgramsTerm
"hello"
let
(
term
,
nre
)
=
simpleTerm
let
nre
=
NgramsRepoElement
{
_nre_size
=
1
,
_nre_list
=
MapTerm
,
_nre_root
=
Nothing
,
_nre_parent
=
Nothing
,
_nre_children
=
MSet
Map
.
empty
}
let
tPatch
=
NgramsReplace
{
_patch_old
=
Nothing
let
tPatch
=
NgramsReplace
{
_patch_old
=
Nothing
,
_patch_new
=
Just
nre
}
,
_patch_new
=
Just
nre
}
ver
<-
currentVersion
listId
ver
<-
currentVersion
listId
...
@@ -321,5 +302,5 @@ commitPatchSimpleTest env = do
...
@@ -321,5 +302,5 @@ commitPatchSimpleTest env = do
liftIO
$
do
liftIO
$
do
ns
<-
atomically
$
readTVar
v
ns
<-
atomically
$
readTVar
v
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
ns
`
shouldBe
`
(
NodeStory
$
Map
.
singleton
listId
(
(
initArchive
::
ArchiveList
)
{
_a_state
=
Map
.
singleton
NgramsTerms
nls
(
initArchiveList
{
_a_state
=
Map
.
singleton
NgramsTerms
nls
,
_a_version
=
ver
+
1
}))
,
_a_version
=
ver
+
1
}))
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment