我目前有以下测试代码:
testUpdate :: Test
testUpdate = testCase "update does change artist" $ do
  (created, Just revised, parents) <- mbTest $ do
    Just editor <- fmap entityRef <$> findEditorByName "acid2"
    created <- create editor startWith
    let artistId = coreMbid created
    newRev <- update editor (coreRevision created) expected
    editId <- openEdit
    includeRevision editId newRev
    apply editId
    found <- findLatest artistId
    parents <- revisionParents newRev
    return (created, found, parents)
  coreData revised @?= expected
  assertBool "The old revision is a direct parent of the new revision" $
    parents == [coreRevision created]
  where
    startWith = ...
    expected = ...
这有点工作,但它很乱。我宁愿能够编写一些东西而不必返回各种被测试的东西,而是在它们有意义的地方拥有断言。
我看到有Assertable课程,但似乎我最终可能不得不重新发明一堆东西。