Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Open sidebar
ld
go-car
Commits
dde2a732
Commit
dde2a732
authored
Jun 03, 2021
by
Rod Vagg
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
chore: refactor header tests to iterate over a struct
parent
2876c180
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
66 additions
and
58 deletions
+66
-58
car_test.go
car_test.go
+66
-58
No files found.
car_test.go
View file @
dde2a732
...
@@ -237,6 +237,58 @@ func TestEOFHandling(t *testing.T) {
...
@@ -237,6 +237,58 @@ func TestEOFHandling(t *testing.T) {
}
}
func
TestBadHeaders
(
t
*
testing
.
T
)
{
func
TestBadHeaders
(
t
*
testing
.
T
)
{
testCases
:=
[]
struct
{
name
string
hex
string
errStr
string
// either the whole error string
errPfx
string
// or just the prefix
}{
{
"{version:2}"
,
"0aa16776657273696f6e02"
,
"invalid car version: 2"
,
""
,
},
{
// an unfortunate error because we don't use a pointer
"{roots:[baeaaaa3bmjrq]}"
,
"13a165726f6f747381d82a480001000003616263"
,
"invalid car version: 0"
,
""
,
},
{
"{version:
\"
1
\"
,roots:[baeaaaa3bmjrq]}"
,
"1da265726f6f747381d82a4800010000036162636776657273696f6e6131"
,
""
,
"invalid header: "
,
},
{
"{version:1}"
,
"0aa16776657273696f6e01"
,
"empty car, no roots"
,
""
,
},
{
"{version:1,roots:{cid:baeaaaa3bmjrq}}"
,
"20a265726f6f7473a163636964d82a4800010000036162636776657273696f6e01"
,
""
,
"invalid header: "
,
},
{
"{version:1,roots:[baeaaaa3bmjrq],blip:true}"
,
"22a364626c6970f565726f6f747381d82a4800010000036162636776657273696f6e01"
,
""
,
"invalid header: "
,
},
{
"[1,[]]"
,
"03820180"
,
""
,
"invalid header: "
,
},
{
// this is an unfortunate error, it'd be nice to catch it better but it's
// very unlikely we'd ever see this in practice
"null"
,
"01f6"
,
""
,
"invalid car version: 0"
,
},
}
makeCar
:=
func
(
t
*
testing
.
T
,
byts
string
)
error
{
makeCar
:=
func
(
t
*
testing
.
T
,
byts
string
)
error
{
fixture
,
err
:=
hex
.
DecodeString
(
byts
)
fixture
,
err
:=
hex
.
DecodeString
(
byts
)
if
err
!=
nil
{
if
err
!=
nil
{
...
@@ -253,62 +305,18 @@ func TestBadHeaders(t *testing.T) {
...
@@ -253,62 +305,18 @@ func TestBadHeaders(t *testing.T) {
}
}
})
})
t
.
Run
(
"{version:2}"
,
func
(
t
*
testing
.
T
)
{
for
_
,
tc
:=
range
testCases
{
err
:=
makeCar
(
t
,
"0aa16776657273696f6e02"
)
t
.
Run
(
tc
.
name
,
func
(
t
*
testing
.
T
)
{
if
err
.
Error
()
!=
"invalid car version: 2"
{
err
:=
makeCar
(
t
,
tc
.
hex
)
t
.
Fatalf
(
"bad error: %v"
,
err
)
if
tc
.
errStr
!=
""
{
}
if
err
.
Error
()
!=
tc
.
errStr
{
})
t
.
Fatalf
(
"bad error: %v"
,
err
)
}
// an unfortunate error because we don't use a pointer
}
else
{
t
.
Run
(
"{roots:[baeaaaa3bmjrq]}"
,
func
(
t
*
testing
.
T
)
{
if
!
strings
.
HasPrefix
(
err
.
Error
(),
tc
.
errPfx
)
{
err
:=
makeCar
(
t
,
"13a165726f6f747381d82a480001000003616263"
)
t
.
Fatalf
(
"bad error: %v"
,
err
)
if
err
.
Error
()
!=
"invalid car version: 0"
{
}
t
.
Fatalf
(
"bad error: %v"
,
err
)
}
}
})
})
}
t
.
Run
(
"{version:
\"
1
\"
,roots:[baeaaaa3bmjrq]}"
,
func
(
t
*
testing
.
T
)
{
err
:=
makeCar
(
t
,
"1da265726f6f747381d82a4800010000036162636776657273696f6e6131"
)
if
!
strings
.
HasPrefix
(
err
.
Error
(),
"invalid header: "
)
{
t
.
Fatalf
(
"bad error: %v"
,
err
)
}
})
t
.
Run
(
"{version:1}"
,
func
(
t
*
testing
.
T
)
{
err
:=
makeCar
(
t
,
"0aa16776657273696f6e01"
)
if
err
.
Error
()
!=
"empty car, no roots"
{
t
.
Fatalf
(
"bad error: %v"
,
err
)
}
})
t
.
Run
(
"{version:1,roots:{cid:baeaaaa3bmjrq}}"
,
func
(
t
*
testing
.
T
)
{
err
:=
makeCar
(
t
,
"20a265726f6f7473a163636964d82a4800010000036162636776657273696f6e01"
)
if
!
strings
.
HasPrefix
(
err
.
Error
(),
"invalid header: "
)
{
t
.
Fatalf
(
"bad error: %v"
,
err
)
}
})
t
.
Run
(
"{version:1,roots:[baeaaaa3bmjrq],blip:true}"
,
func
(
t
*
testing
.
T
)
{
err
:=
makeCar
(
t
,
"22a364626c6970f565726f6f747381d82a4800010000036162636776657273696f6e01"
)
if
!
strings
.
HasPrefix
(
err
.
Error
(),
"invalid header: "
)
{
t
.
Fatalf
(
"bad error: %v"
,
err
)
}
})
t
.
Run
(
"[1,[]]"
,
func
(
t
*
testing
.
T
)
{
err
:=
makeCar
(
t
,
"03820180"
)
if
!
strings
.
HasPrefix
(
err
.
Error
(),
"invalid header: "
)
{
t
.
Fatalf
(
"bad error: %v"
,
err
)
}
})
// this is an unfortunate error, it'd be nice to catch it better but it's
// very unlikely we'd ever see this in practice
t
.
Run
(
"null"
,
func
(
t
*
testing
.
T
)
{
err
:=
makeCar
(
t
,
"01f6"
)
if
!
strings
.
HasPrefix
(
err
.
Error
(),
"invalid car version: 0"
)
{
t
.
Fatalf
(
"bad error: %v"
,
err
)
}
})
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment