• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

lightningnetwork / lnd / 17191871672

24 Aug 2025 05:44PM UTC coverage: 66.162% (+8.8%) from 57.321%
17191871672

Pull #9147

github

web-flow
Merge edec0450e into 0c2f045f5
Pull Request #9147: [Part 1|3] Introduce SQL Payment schema into LND

72 of 1878 new or added lines in 12 files covered. (3.83%)

17 existing lines in 7 files now uncovered.

135954 of 205487 relevant lines covered (66.16%)

21319.58 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

64.29
/sqldb/sqlutils.go
1
package sqldb
2

3
import (
4
        "database/sql"
5
        "time"
6

7
        "golang.org/x/exp/constraints"
8
)
9

10
// NoOpReset is a no-op function that can be used as a default
11
// reset function ExecTx calls.
12
var NoOpReset = func() {}
22,435✔
13

14
// SQLInt16 turns a numerical integer type into the NullInt16 that sql/sqlc
15
// uses when an integer field can be permitted to be NULL.
16
//
17
// We use this constraints.Integer constraint here which maps to all signed and
18
// unsigned integer types.
19
func SQLInt16[T constraints.Integer](num T) sql.NullInt16 {
×
20
        return sql.NullInt16{
×
21
                Int16: int16(num),
×
22
                Valid: true,
×
23
        }
×
24
}
×
25

26
// SQLInt32 turns a numerical integer type into the NullInt32 that sql/sqlc
27
// uses when an integer field can be permitted to be NULL.
28
//
29
// We use this constraints.Integer constraint here which maps to all signed and
30
// unsigned integer types.
31
func SQLInt32[T constraints.Integer](num T) sql.NullInt32 {
20,592✔
32
        return sql.NullInt32{
20,592✔
33
                Int32: int32(num),
20,592✔
34
                Valid: true,
20,592✔
35
        }
20,592✔
36
}
20,592✔
37

38
// SQLInt64 turns a numerical integer type into the NullInt64 that sql/sqlc
39
// uses when an integer field can be permitted to be NULL.
40
//
41
// We use this constraints.Integer constraint here which maps to all signed and
42
// unsigned integer types.
43
func SQLInt64[T constraints.Integer](num T) sql.NullInt64 {
27,165✔
44
        return sql.NullInt64{
27,165✔
45
                Int64: int64(num),
27,165✔
46
                Valid: true,
27,165✔
47
        }
27,165✔
48
}
27,165✔
49

50
// SQLStr turns a string into the NullString that sql/sqlc uses when a string
51
// can be permitted to be NULL.
52
func SQLStr(s string) sql.NullString {
20,592✔
53
        if s == "" {
20,972✔
54
                return sql.NullString{}
380✔
55
        }
380✔
56

57
        return sql.NullString{
20,212✔
58
                String: s,
20,212✔
59
                Valid:  true,
20,212✔
60
        }
20,212✔
61
}
62

63
// SQLBool turns a boolean into the NullBool that sql/sqlc uses when a boolean
64
// can be permitted to be NULL.
NEW
65
func SQLBool(b bool) sql.NullBool {
×
NEW
66
        return sql.NullBool{
×
NEW
67
                Bool:  b,
×
NEW
68
                Valid: true,
×
NEW
69
        }
×
NEW
70
}
×
71

72
// SQLTime turns a time.Time into the NullTime that sql/sqlc uses when a time
73
// can be permitted to be NULL.
74
func SQLTime(t time.Time) sql.NullTime {
69,247✔
75
        return sql.NullTime{
69,247✔
76
                Time:  t,
69,247✔
77
                Valid: true,
69,247✔
78
        }
69,247✔
79
}
69,247✔
80

81
// ExtractSqlInt16 turns a NullInt16 into a numerical type. This can be useful
82
// when reading directly from the database, as this function handles extracting
83
// the inner value from the "option"-like struct.
84
func ExtractSqlInt16[T constraints.Integer](num sql.NullInt16) T {
×
85
        return T(num.Int16)
×
86
}
×
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc