-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsql_mock.go
51 lines (47 loc) · 1.09 KB
/
sql_mock.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// Copyright (c) 2023 Eli Janssen
// Use of this source code is governed by an MIT-style
// license that can be found in the LICENSE file.
package refid
// A matcher that supports the following interfaces:
// - [github.com/pashagolub/pgxmock/v3.Argument]
// - [github.com/DATA-DOG/go-sqlmock.Argument]
type AnyMatcher struct {
tag byte
}
// Create a [AnyMatcher] matcher that matches that matches against a specific
// Tag. Any valid IDs that do not match the tag specified, will be considered
// not matching.
//
// If tag is 0, will support matching any ID (tag is then ignored)
//
// Example usage:
//
// mock.ExpectQuery("^INSERT INTO some_table (.+)").
// WithArgs(refid.MatchAny(1), 1).
// WillReturnRows(rows)
func MatchAny(tag byte) AnyMatcher {
return AnyMatcher{tag}
}
func (a AnyMatcher) Match(v interface{}) bool {
var r ID
var err error
switch x := v.(type) {
case string:
r, err = Parse(x)
case []byte:
r, err = FromBytes(x)
case ID:
r = x
case *ID:
r = *x
default:
return false
}
if err != nil {
return false
}
if a.tag != 0 {
return r.HasTag(a.tag)
}
return true
}