mirror of
				https://github.com/Smaug123/WoofWare.Myriad
				synced 2025-10-25 13:58:40 +00:00 
			
		
		
		
	Implement AllowAnyStatusCode (#41)
This commit is contained in:
		
							
								
								
									
										62
									
								
								MyriadPlugin.Test/TestAllowAnyStatusCode.fs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								MyriadPlugin.Test/TestAllowAnyStatusCode.fs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | ||||
| namespace MyriadPlugin.Test | ||||
|  | ||||
| open System | ||||
| open System.Net | ||||
| open System.Net.Http | ||||
| open NUnit.Framework | ||||
| open FsUnitTyped | ||||
| open PureGym | ||||
|  | ||||
| [<TestFixture>] | ||||
| module TestAllowAnyStatusCode = | ||||
|  | ||||
|     [<Test>] | ||||
|     let ``Without AllowAnyStatusCode we throw`` () = | ||||
|         let proc (message : HttpRequestMessage) : HttpResponseMessage Async = | ||||
|             async { | ||||
|                 message.Method |> shouldEqual HttpMethod.Get | ||||
|                 let content = new StringContent ("nothing was here :(") | ||||
|                 let resp = new HttpResponseMessage (HttpStatusCode.NotFound) | ||||
|                 resp.Content <- content | ||||
|                 return resp | ||||
|             } | ||||
|  | ||||
|         use client = HttpClientMock.make (Uri "https://example.com") proc | ||||
|         let api = PureGymApi.make client | ||||
|  | ||||
|         let exc = | ||||
|             async { | ||||
|                 let! message = Async.AwaitTask (api.GetWithoutAnyReturnCode ()) |> Async.Catch | ||||
|  | ||||
|                 match message with | ||||
|                 | Choice1Of2 _ -> return failwith "test failure" | ||||
|                 | Choice2Of2 exc -> return exc | ||||
|             } | ||||
|             |> Async.RunSynchronously | ||||
|  | ||||
|         let exc = | ||||
|             match exc with | ||||
|             | :? AggregateException as exc -> exc | ||||
|             | exc -> failwith $"Test failure: expected AggregateException, got %+A{exc}" | ||||
|  | ||||
|         match exc.InnerException with | ||||
|         | :? HttpRequestException as exc -> exc.Message.Contains "404 (Not Found)" |> shouldEqual true | ||||
|         | e -> failwith $"Test failure: %+A{e}" | ||||
|  | ||||
|     [<Test>] | ||||
|     let ``With AllowAnyStatusCode we do not throw`` () = | ||||
|         let proc (message : HttpRequestMessage) : HttpResponseMessage Async = | ||||
|             async { | ||||
|                 message.Method |> shouldEqual HttpMethod.Get | ||||
|                 let content = new StringContent ("nothing was here :(") | ||||
|                 let resp = new HttpResponseMessage (HttpStatusCode.NotFound) | ||||
|                 resp.Content <- content | ||||
|                 return resp | ||||
|             } | ||||
|  | ||||
|         use client = HttpClientMock.make (Uri "https://example.com") proc | ||||
|         let api = PureGymApi.make client | ||||
|  | ||||
|         let message = api.GetWithAnyReturnCode().Result | ||||
|         message.StatusCode |> shouldEqual HttpStatusCode.NotFound | ||||
|         message.Content.ReadAsStringAsync().Result |> shouldEqual "nothing was here :(" | ||||
		Reference in New Issue
	
	Block a user