|
19 | 19 | import java.net.Proxy; |
20 | 20 | import java.util.HashMap; |
21 | 21 | import java.util.Map; |
| 22 | +import java.util.concurrent.TimeUnit; |
22 | 23 |
|
23 | 24 | public class ContentstackUnitTest { |
24 | 25 |
|
@@ -167,6 +168,68 @@ void setTimeout() { |
167 | 168 | Assertions.assertEquals(3, contentstack.timeout); |
168 | 169 | } |
169 | 170 |
|
| 171 | + @Test |
| 172 | + void setTimeoutZeroThrows() { |
| 173 | + Assertions.assertThrows(IllegalArgumentException.class, |
| 174 | + () -> new Contentstack.Builder().setTimeout(0)); |
| 175 | + } |
| 176 | + |
| 177 | + @Test |
| 178 | + void setTimeoutNegativeThrows() { |
| 179 | + Assertions.assertThrows(IllegalArgumentException.class, |
| 180 | + () -> new Contentstack.Builder().setTimeout(-1)); |
| 181 | + } |
| 182 | + |
| 183 | + @Test |
| 184 | + void setReadTimeoutZeroThrows() { |
| 185 | + Assertions.assertThrows(IllegalArgumentException.class, |
| 186 | + () -> new Contentstack.Builder().setReadTimeout(0)); |
| 187 | + } |
| 188 | + |
| 189 | + @Test |
| 190 | + void setWriteTimeoutNegativeThrows() { |
| 191 | + Assertions.assertThrows(IllegalArgumentException.class, |
| 192 | + () -> new Contentstack.Builder().setWriteTimeout(-5)); |
| 193 | + } |
| 194 | + |
| 195 | + @Test |
| 196 | + void setConnectTimeoutInvalidThrows() { |
| 197 | + Assertions.assertThrows(IllegalArgumentException.class, |
| 198 | + () -> new Contentstack.Builder().setConnectTimeout(-1)); |
| 199 | + } |
| 200 | + |
| 201 | + @Test |
| 202 | + void okHttpTimeoutsMatchSetTimeout() { |
| 203 | + Contentstack client = new Contentstack.Builder().setTimeout(45).build(); |
| 204 | + OkHttpClient ok = (OkHttpClient) client.instance.callFactory(); |
| 205 | + Assertions.assertEquals(45_000, ok.connectTimeoutMillis()); |
| 206 | + Assertions.assertEquals(45_000, ok.readTimeoutMillis()); |
| 207 | + Assertions.assertEquals(45_000, ok.writeTimeoutMillis()); |
| 208 | + } |
| 209 | + |
| 210 | + @Test |
| 211 | + void okHttpDefaultTimeoutsUseUtilTimeout() { |
| 212 | + Contentstack client = new Contentstack.Builder().build(); |
| 213 | + OkHttpClient ok = (OkHttpClient) client.instance.callFactory(); |
| 214 | + int expectedMs = (int) TimeUnit.SECONDS.toMillis(30); |
| 215 | + Assertions.assertEquals(expectedMs, ok.connectTimeoutMillis()); |
| 216 | + Assertions.assertEquals(expectedMs, ok.readTimeoutMillis()); |
| 217 | + Assertions.assertEquals(expectedMs, ok.writeTimeoutMillis()); |
| 218 | + } |
| 219 | + |
| 220 | + @Test |
| 221 | + void okHttpPerLegOverridesFallBackToSetTimeout() { |
| 222 | + Contentstack client = new Contentstack.Builder() |
| 223 | + .setTimeout(10) |
| 224 | + .setReadTimeout(90) |
| 225 | + .build(); |
| 226 | + OkHttpClient ok = (OkHttpClient) client.instance.callFactory(); |
| 227 | + Assertions.assertEquals(10_000, ok.connectTimeoutMillis()); |
| 228 | + Assertions.assertEquals(90_000, ok.readTimeoutMillis()); |
| 229 | + Assertions.assertEquals(10_000, ok.writeTimeoutMillis()); |
| 230 | + Assertions.assertEquals(10, client.timeout); |
| 231 | + } |
| 232 | + |
170 | 233 | @Test |
171 | 234 | void testSetAuthtoken() { |
172 | 235 | Contentstack contentstack = new Contentstack.Builder() |
|
0 commit comments