1 {-# LANGUAGE DeriveAnyClass #-}
2 {-# LANGUAGE OverloadedLists #-}
3 {-# LANGUAGE OverloadedStrings #-}
5 module Tests.Invoice where
7 import Data.List qualified as List
8 import Data.Text.Lazy qualified as Text.Lazy
9 import Data.Time.Clock qualified as Time
10 import Data.Time.LocalTime qualified as Time
11 import Test.Syd (Spec, describe, goldenByteStringBuilderFile, it)
12 import Tests.Utils.Tests (goldenPath)
13 import Text.Blaze.Renderer.Text qualified as Blaze.Text
14 import Text.Blaze.Renderer.Utf8 qualified as Blaze
17 import Literate.Accounting (Amount, Unit (UnitName))
18 import Literate.Database
19 import Literate.Document.HTML qualified as HTML
20 import Literate.Invoice
21 import Literate.Invoice.HTML (invoiceIdInline)
22 import Literate.Invoice.HTML qualified as HTML
23 import Literate.Prelude
25 import Tests.Organization
28 spec :: HasCallStack => Spec
31 forM_ invoices \invId -> do
33 inv = invId & get @(Invoice ScopeId ActionId EntityId InvoiceId)
38 & Blaze.Text.renderMarkup
40 outPath <- goldenPath idS "html"
42 goldenByteStringBuilderFile outPath do
43 inv & HTML.htmlIO <&> Blaze.renderMarkupBuilder
50 deriving (Eq, Ord, Show, Generic, Enum, NFData)
52 instance Get (Invoice ScopeId ActionId EntityId InvoiceId) InvoiceId where
53 get invoiceId = case invoiceId of
57 , invoiceType = InvoiceTypeSale
60 , invoicePaymentDueBefore = invoiceEmittedOn & Time.addLocalTime (31 * Time.nominalDay)
61 , invoiceIssuer = EntityJulmInfo
62 , invoiceRecipient = EntityJulmInfo
63 , invoiceRates = [Action_Develop := 0]
65 [ InvoiceMentionTVANonApplicable
66 , InvoiceMentionIndemnitéForfaitaire
67 , InvoiceMentionIndemnitéTaux (12.15 :: Amount 100 (UnitName "%"))
71 { workDate = "2000-01-01"
73 , workAction = Action_Develop
76 , workDescription = ""
81 invoiceEmittedOn = "2026-01-22"
85 , invoiceType = InvoiceTypeSale
86 , invoiceOrders = ["Contract n°2025-24"]
88 , invoicePaymentDueBefore = invoiceEmittedOn & Time.addLocalTime (31 * Time.nominalDay)
89 , invoiceIssuer = EntityJulmInfo
90 , invoiceRecipient = EntityNixOSFoundationNGITeam
92 [ Action_Debug := 31.25
93 , Action_Organize := 31.25
94 , Action_Develop := 31.25
95 , Action_Document := 31.25
96 , Action_Review := 31.25
99 [ InvoiceMentionTVANonApplicable
100 , InvoiceMentionIndemnitéForfaitaire
101 , InvoiceMentionIndemnitéTaux (12.15 :: Amount 100 (UnitName "%"))
105 & List.filter \work ->
108 [ work & workDate & (>= "2025-11-06")
109 , work & workDate & (<= "2025-12-22")
110 , work & workScope & (/= [Scope_NGIpkgs_Manuals])
114 invoiceEmittedOn = "2026-01-22"
118 , invoiceType = InvoiceTypeSale
119 , invoiceOrders = ["contract n°2026-03"]
121 , invoicePaymentDueBefore = invoiceEmittedOn & Time.addLocalTime (31 * Time.nominalDay)
122 , invoiceIssuer = EntityJulmInfo
123 , invoiceRecipient = EntityNixOSFoundationNGITeam
125 [ Action_Debug := 31.25
126 , Action_Organize := 31.25
127 , Action_Develop := 31.25
128 , Action_Document := 31.25
129 , Action_Review := 31.25
132 [ InvoiceMentionTVANonApplicable
133 , InvoiceMentionIndemnitéForfaitaire
134 , InvoiceMentionIndemnitéTaux (12.15 :: Amount 100 (UnitName "%"))
138 & List.filter \work ->
140 [ work & workDate & (>= "2025-12-23")
141 , work & workDate & (<= "2026-12-31")
142 , work & workScope & (/= [Scope_NGIpkgs_Manuals])
143 , work & workScope & (/= [Scope_NGIpkgs, Scope_Funkwhale])
146 [ work & workDate & (>= "2026-01-09")
147 , work & workDate & (<= "2026-01-28")
148 , work & workAction & (== Action_Organize)
149 , work & workScope & (== [Scope_NGIpkgs])
156 invoiceEmittedOn = "2026-01-27"
160 , invoiceType = InvoiceTypeSale
161 , invoiceOrders = ["contract n°2026-FixMe"]
163 , invoicePaymentDueBefore = invoiceEmittedOn & Time.addLocalTime (31 * Time.nominalDay)
164 , invoiceIssuer = EntityJulmInfo
165 , invoiceRecipient = EntityNixOSFoundationNGITeam
167 [ Action_Debug := 31.25
168 , Action_Develop := 31.25
169 , Action_Document := 31.25
170 , Action_Organize := 31.25
171 , Action_Review := 31.25
174 [ InvoiceMentionTVANonApplicable
175 , InvoiceMentionIndemnitéForfaitaire
176 , InvoiceMentionIndemnitéTaux (12.15 :: Amount 100 (UnitName "%"))
180 & List.filter \work ->
183 [ work & workDate & (> "2026-01-28")
184 , work & workDate & (<= "2026-12-31")
191 invoiceEmittedOn = "2026-03-31"
193 invoices :: [InvoiceId]