Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Command dedup: add columns to completions in append-only schemas [KVL-1057] #10652

Merged
Changes from 1 commit
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
8dfedb4
Augment completion.proto with deduplication-related info
fabiotudone-da Aug 19, 2021
9768373
Merge branch 'main' into fabiotudone-da/command-dedup/ledger-api-comp…
fabiotudone-da Aug 23, 2021
e43f2fc
Explicitly specify fields not yet filled in when building Completion
fabiotudone-da Aug 23, 2021
d566b97
Time-based deduplication periods are measured in record time of compl…
fabiotudone-da Aug 23, 2021
89336ab
Add deduplication_offset as a deduplication_period option
fabiotudone-da Aug 23, 2021
eb14dd9
Don't skip proto field numbers
fabiotudone-da Aug 23, 2021
1ba2045
CompletionFromTransaction: use default Completion constructor
fabiotudone-da Aug 23, 2021
efa01ff
submission_rank: reserve proto field for future use
fabiotudone-da Aug 23, 2021
73fd7a2
Add comment about reserved proto field
fabiotudone-da Aug 23, 2021
8e54bb5
Add command deduplication columns to completions in append-only schemas
fabiotudone-da Aug 24, 2021
35c6ded
Merge branch 'main' into fabiotudone-da/command-dedup/index-db-add-in…
fabiotudone-da Aug 24, 2021
8079673
Remove duplicated `application_id` field from Postgres and H2 schemas
fabiotudone-da Aug 24, 2021
3e5fa10
Make `application_id` and `submission_id` nullable
fabiotudone-da Aug 24, 2021
f68a130
Re-generate migrations' sha256
fabiotudone-da Aug 24, 2021
abf65e3
Merge branch 'main' into fabiotudone-da/command-dedup/index-db-add-in…
fabiotudone-da Aug 24, 2021
0cb77e4
Tidy-up
fabiotudone-da Aug 25, 2021
1cab32b
Add RW logic for new command dedup columns in completions
fabiotudone-da Aug 25, 2021
156dae8
Merge branch 'main' into fabiotudone-da/command-dedup/index-db-add-in…
fabiotudone-da Aug 25, 2021
6db6a86
Declare `deduplication_start` as a nullable column
fabiotudone-da Aug 25, 2021
484db4a
Fix UpdateToDbDtoSpec
fabiotudone-da Aug 25, 2021
8dbe592
Fix merge from main
fabiotudone-da Aug 25, 2021
19856a2
Replace Either3 with an ADT in StorageBackendTestValues
fabiotudone-da Aug 25, 2021
2ba045d
Test with non-zero nanos
fabiotudone-da Aug 25, 2021
477e219
Fix UpdateToDbDtoSpec
fabiotudone-da Aug 25, 2021
1432308
Also change Schema.scala
fabiotudone-da Aug 26, 2021
0e27dbe
Simplify DbDto.CommandCompletion construction
fabiotudone-da Aug 26, 2021
b7c86d7
Merge branch 'main' into fabiotudone-da/command-dedup/index-db-add-in…
fabiotudone-da Aug 26, 2021
39ded6d
Fix merge from `main` (migration SHAs and filename)
fabiotudone-da Aug 26, 2021
15223de
Fix UpdateToDbDto: restore transactionId
fabiotudone-da Aug 30, 2021
24d1d6e
Fix completions' application_id: it must be non-nullable in all schem…
fabiotudone-da Aug 30, 2021
eb44d3c
Actually use newly read columns
fabiotudone-da Aug 30, 2021
5643b95
Add DB round-trip tests for new fields in StorageBackendTestValues
fabiotudone-da Aug 30, 2021
51ab254
Format
fabiotudone-da Aug 30, 2021
87da1dd
StorageBackendTestValues: property type someSubmissionId
fabiotudone-da Aug 30, 2021
482891e
UpdateToDbDto: remove duplicated logic
fabiotudone-da Aug 30, 2021
804c99e
Simplify UpdateToDbDto.commandCompletion
fabiotudone-da Aug 30, 2021
f32346e
Fix comment in CompletionFromTransaction.toApiDeduplicationPeriod
fabiotudone-da Aug 30, 2021
4ebd1e0
Fix CompletionFromTransaction.toApiCompletion
fabiotudone-da Aug 30, 2021
b1bc3d4
Fix deduplication_offset in Schema
fabiotudone-da Aug 30, 2021
85ed113
Make parameters explicit in CompletionFromTransaction and CompletionS…
fabiotudone-da Aug 30, 2021
8da5af0
Shorten error message in CompletionFromTransaction
fabiotudone-da Aug 30, 2021
166cd83
Fix StorageBackendTestsCompletions
fabiotudone-da Aug 30, 2021
3b7a9e5
Fix CompletionFromTransaction
fabiotudone-da Aug 30, 2021
bde3d1e
Separate command dedup-related test cases in UpdateToDbDtoSpec
fabiotudone-da Aug 31, 2021
4a94562
Simplify further UpdateToDbDto.commandCompletion
fabiotudone-da Aug 31, 2021
2749c75
Simplify CompletionFromTransaction.toApiCompletion
fabiotudone-da Aug 31, 2021
db74dd0
Format
fabiotudone-da Aug 31, 2021
9c305fc
Merge branch 'main' into fabiotudone-da/command-dedup/index-db-add-in…
fabiotudone-da Aug 31, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Simplify UpdateToDbDto.commandCompletion
  • Loading branch information
fabiotudone-da committed Aug 30, 2021
commit 804c99e9dac488a03319c99991814cf86fd5a2ea
Original file line number Diff line number Diff line change
Expand Up @@ -270,20 +270,15 @@ object UpdateToDbDto {
): DbDto.CommandCompletion = {
val (deduplicationOffset, deduplicationTimeSeconds, deduplicationTimeNanos) =
completionInfo.optDeduplicationPeriod
.flatMap {
.map {
case DeduplicationOffset(offset) =>
Some(Left(offset))
case DeduplicationDuration(duration) =>
Some(Right((duration.getSeconds, duration.getNano)))
}
.fold[(Option[String], Option[Long], Option[Int])] {
(None, None, None)
} {
case Left(offset) =>
(Some(offset.toHexString), None, None)
case Right((seconds, nanos)) =>
(None, Some(seconds), Some(nanos))
}
case DeduplicationDuration(duration) =>
(None, Some(duration.getSeconds), Some(duration.getNano))
} match {
case Some(value) => value
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

how about .getOrElse((None, None, None)) instead?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

case _ => (None, None, None)
}

DbDto.CommandCompletion(
completion_offset = offset.toHexString,
Expand Down