blob: 079be0205e677f2a462b2d465c23e1e29ea5b524 [file] [log] [blame]
Nobuaki Sukegawaef2b5282015-12-11 02:24:17 +09001--
2-- Licensed to the Apache Software Foundation (ASF) under one
3-- or more contributor license agreements. See the NOTICE file
4-- distributed with this work for additional information
5-- regarding copyright ownership. The ASF licenses this file
6-- to you under the Apache License, Version 2.0 (the
7-- "License"); you may not use this file except in compliance
8-- with the License. You may obtain a copy of the License at
9--
10-- http://www.apache.org/licenses/LICENSE-2.0
11--
12-- Unless required by applicable law or agreed to in writing,
13-- software distributed under the License is distributed on an
14-- "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15-- KIND, either express or implied. See the License for the
16-- specific language governing permissions and limitations
17-- under the License.
18--
19
20module JSONSpec where
21
22import Test.Hspec
23import Test.Hspec.QuickCheck (prop)
24
25import qualified Data.ByteString.Lazy.Char8 as C
26
27import Thrift.Types
28import Thrift.Transport
29import Thrift.Transport.Memory
30import Thrift.Protocol
31import Thrift.Protocol.JSON
32
33tString :: [Char] -> ThriftVal
34tString = TString . C.pack
35
36spec :: Spec
37spec = do
38 describe "JSONProtocol" $ do
39 describe "bool" $ do
40 it "writes true as 1" $ do
41 let val = True
42 trans <- openMemoryBuffer
43 let proto = JSONProtocol trans
44 writeVal proto (TBool val)
45 bin <-tRead trans 100
46 (C.unpack bin) `shouldBe` ['1']
47
48 it "writes false as 0" $ do
49 let val = False
50 trans <- openMemoryBuffer
51 let proto = JSONProtocol trans
52 writeVal proto (TBool val)
53 bin <- tRead trans 100
54 (C.unpack bin) `shouldBe` ['0']
55
56 prop "round trip" $ \val -> do
57 trans <- openMemoryBuffer
58 let proto = JSONProtocol trans
59 writeVal proto $ TBool val
60 val2 <- readVal proto T_BOOL
61 val2 `shouldBe` (TBool val)
62
63 describe "string" $ do
64 it "writes" $ do
65 trans <- openMemoryBuffer
66 let proto = JSONProtocol trans
67 writeVal proto (TString $ C.pack "\"a")
68 bin <- tRead trans 100
69 (C.unpack bin) `shouldBe` "\"\\\"a\""
70
71 it "reads" $ do
72 trans <- openMemoryBuffer
73 let proto = JSONProtocol trans
74 tWrite trans $ C.pack "\"\\\"a\""
75 val <- readVal proto (T_STRING)
76 val `shouldBe` (TString $ C.pack "\"a")
77
78 prop "round trip" $ \val -> do
79 trans <- openMemoryBuffer
80 let proto = JSONProtocol trans
81 writeVal proto (TString $ C.pack val)
82 val2 <- readVal proto (T_STRING)
83 val2 `shouldBe` (TString $ C.pack val)
84
85 describe "list" $ do
86 it "writes empty list" $ do
87 trans <- openMemoryBuffer
88 let proto = JSONProtocol trans
89 writeVal proto (TList T_BYTE [])
90 bin <- tRead trans 100
91 (C.unpack bin) `shouldBe` "[\"i8\",0]"
92
93 it "reads empty" $ do
94 trans <- openMemoryBuffer
95 let proto = JSONProtocol trans
96 tWrite trans (C.pack "[\"i8\",0]")
97 val <- readVal proto (T_LIST T_BYTE)
98 val `shouldBe` (TList T_BYTE [])
99
100 it "writes single element" $ do
101 trans <- openMemoryBuffer
102 let proto = JSONProtocol trans
103 writeVal proto (TList T_BYTE [TByte 0])
104 bin <- tRead trans 100
105 (C.unpack bin) `shouldBe` "[\"i8\",1,0]"
106
107 it "reads single element" $ do
108 trans <- openMemoryBuffer
109 let proto = JSONProtocol trans
110 tWrite trans (C.pack "[\"i8\",1,0]")
111 val <- readVal proto (T_LIST T_BYTE)
112 val `shouldBe` (TList T_BYTE [TByte 0])
113
114 it "reads elements" $ do
115 trans <- openMemoryBuffer
116 let proto = JSONProtocol trans
117 tWrite trans (C.pack "[\"i8\",2,42, 43]")
118 val <- readVal proto (T_LIST T_BYTE)
119 val `shouldBe` (TList T_BYTE [TByte 42, TByte 43])
120
121 prop "round trip" $ \val -> do
122 trans <- openMemoryBuffer
123 let proto = JSONProtocol trans
124 writeVal proto $ (TList T_STRING $ map tString val)
125 val2 <- readVal proto $ T_LIST T_STRING
126 val2 `shouldBe` (TList T_STRING $ map tString val)
127
128 describe "set" $ do
129 it "writes empty" $ do
130 trans <- openMemoryBuffer
131 let proto = JSONProtocol trans
132 writeVal proto (TSet T_BYTE [])
133 bin <- tRead trans 100
134 (C.unpack bin) `shouldBe` "[\"i8\",0]"
135
136 it "reads empty" $ do
137 trans <- openMemoryBuffer
138 let proto = JSONProtocol trans
139 tWrite trans (C.pack "[\"i8\",0]")
140 val <- readVal proto (T_SET T_BYTE)
141 val `shouldBe` (TSet T_BYTE [])
142
143 it "reads single element" $ do
144 trans <- openMemoryBuffer
145 let proto = JSONProtocol trans
146 tWrite trans (C.pack "[\"i8\",1,0]")
147 val <- readVal proto (T_SET T_BYTE)
148 val `shouldBe` (TSet T_BYTE [TByte 0])
149
150 it "reads elements" $ do
151 trans <- openMemoryBuffer
152 let proto = JSONProtocol trans
153 tWrite trans (C.pack "[\"i8\",2,42, 43]")
154 val <- readVal proto (T_SET T_BYTE)
155 val `shouldBe` (TSet T_BYTE [TByte 42, TByte 43])
156
157 prop "round trip" $ \val -> do
158 trans <- openMemoryBuffer
159 let proto = JSONProtocol trans
160 writeVal proto $ (TSet T_STRING $ map tString val)
161 val2 <- readVal proto $ T_SET T_STRING
162 val2 `shouldBe` (TSet T_STRING $ map tString val)
163
164 describe "map" $ do
165 it "writes empty" $ do
166 trans <- openMemoryBuffer
167 let proto = JSONProtocol trans
168 writeVal proto (TMap T_BYTE T_BYTE [])
169 bin <- tRead trans 100
170 (C.unpack bin) `shouldBe`"[\"i8\",\"i8\",0,{}]"
171
172 it "reads empty" $ do
173 trans <- openMemoryBuffer
174 let proto = JSONProtocol trans
175 tWrite trans (C.pack "[\"i8\",\"i8\",0,{}]")
176 val <- readVal proto (T_MAP T_BYTE T_BYTE)
177 val `shouldBe` (TMap T_BYTE T_BYTE [])
178
179 it "reads string-string" $ do
180 let bin = "[\"str\",\"str\",2,{\"a\":\"2\",\"b\":\"blah\"}]"
181 trans <- openMemoryBuffer
182 let proto = JSONProtocol trans
183 tWrite trans (C.pack bin)
184 val <- readVal proto (T_MAP T_STRING T_STRING)
185 val`shouldBe` (TMap T_STRING T_STRING [(tString "a", tString "2"), (tString "b", tString "blah")])
186
187 prop "round trip" $ \val -> do
188 trans <- openMemoryBuffer
189 let proto = JSONProtocol trans
190 writeVal proto $ (TMap T_STRING T_STRING $ map toKV val)
191 val2 <- readVal proto $ T_MAP T_STRING T_STRING
192 val2 `shouldBe` (TMap T_STRING T_STRING $ map toKV val)
193 where
194 toKV v = (tString v, tString v)
195