forked from getconversio/go-shopify
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathoauth_test.go
94 lines (77 loc) · 2.94 KB
/
oauth_test.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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
package goshopify
import (
"net/url"
"testing"
"gopkg.in/jarcoal/httpmock.v1"
)
func TestAppAuthorizeUrl(t *testing.T) {
setup()
defer teardown()
cases := []struct {
shopName string
nonce string
expected string
}{
{"fooshop", "thenonce", "https://fooshop.myshopify.com/admin/oauth/authorize?client_id=apikey&redirect_uri=https%3A%2F%2Fexample.com%2Fcallback&scope=read_products&state=thenonce"},
}
for _, c := range cases {
actual := app.AuthorizeUrl(c.shopName, c.nonce)
if actual != c.expected {
t.Errorf("App.AuthorizeUrl(): expected %s, actual %s", c.expected, actual)
}
}
}
func TestAppGetAccessToken(t *testing.T) {
setup()
defer teardown()
httpmock.RegisterResponder("POST", "https://fooshop.myshopify.com/admin/oauth/access_token",
httpmock.NewStringResponder(200, `{"access_token":"footoken"}`))
token, err := app.GetAccessToken("fooshop", "foocode")
if err != nil {
t.Fatalf("App.GetAccessToken(): %v", err)
}
expected := "footoken"
if token != expected {
t.Errorf("Token = %v, expected %v", token, expected)
}
}
func TestAppVerifyAuthorizationURL(t *testing.T) {
// These credentials are from the Shopify example page:
// https://help.shopify.com/api/guides/authentication/oauth#verification
urlOk, _ := url.Parse("http://example.com/callback?code=0907a61c0c8d55e99db179b68161bc00&hmac=4712bf92ffc2917d15a2f5a273e39f0116667419aa4b6ac0b3baaf26fa3c4d20&shop=some-shop.myshopify.com&signature=11813d1e7bbf4629edcda0628a3f7a20×tamp=1337178173")
urlOkWithState, _ := url.Parse("http://example.com/callback?code=0907a61c0c8d55e99db179b68161bc00&hmac=7db6973c2aff68295ebcf354c2ce528a6b09aef1146baafccc2e0b369fff5f6d&shop=some-shop.myshopify.com&signature=11813d1e7bbf4629edcda0628a3f7a20×tamp=1337178173&state=abcd")
urlNotOk, _ := url.Parse("http://example.com/callback?code=0907a61c0c8d55e99db179b68161bc00&hmac=4712bf92ffc2917d15a2f5a273e39f0116667419aa4b6ac0b3baaf26fa3c4d20&shop=some-shop.myshopify.com&signature=11813d1e7bbf4629edcda0628a3f7a20×tamp=133717817")
cases := []struct {
u *url.URL
expected bool
}{
{urlOk, true},
{urlOkWithState, true},
{urlNotOk, false},
}
for _, c := range cases {
actual, err := app.VerifyAuthorizationURL(c.u)
if err != nil {
t.Errorf("App.VerifyAuthorizationURL(..., %s) returned an error: %v", c.u, err)
}
if actual != c.expected {
t.Errorf("App.VerifyAuthorizationURL(..., %s): expected %v, actual %v", c.u, c.expected, actual)
}
}
}
func TestVerifyWebhookRequest(t *testing.T) {
setup()
defer teardown()
hmac := "hMTq0K2x7oyOjoBwGYeTj5oxfnaVYXzbanUG9aajpKI="
message := "my secret message"
testClient := NewClient(App{}, "", "")
req, err := testClient.NewRequest("GET", "", message, nil)
if err != nil {
t.Fatalf("Webhook.verify err = %v, expected true", err)
}
req.Header.Add("X-Shopify-Hmac-Sha256", hmac)
isValid := app.VerifyWebhookRequest(req)
if !isValid {
t.Error("Webhook.verify could not verified message checksum")
}
}