Ejemplo n.º 1
0
    public async Task SendRemovesSentRequestsFromQueue()
    {
        //arrange
        var config     = new ServerConfig(new Uri("http://localhost"), Guid.NewGuid().ToString(), TimeSpan.MaxValue);
        var http       = new MockHttpMessageHandler();
        var httpClient = new HttpClient(http);
        var agent      = new QueuedAgent(config, httpClient);
        var r1         = new Request {
            Action = "a1"
        };
        var r2 = new Request {
            Action = "a2"
        };
        var r3 = new Request {
            Action = "a3"
        };
        await agent.Send(r1);

        await agent.Send(r2);

        await agent.Send(r3);

        //act
        var toSend = new[] { r1, r2 };
        await agent.PostRequests(toSend);

        //assert
        var remaining = agent.GetOutstandingRequests();

        Assert.DoesNotContain(r1, remaining);
        Assert.DoesNotContain(r2, remaining);
        Assert.Contains(r3, remaining);
    }
Ejemplo n.º 2
0
    public async Task SendRequestsCallsHttpPost()
    {
        //arrange
        var config   = new ServerConfig(new Uri("http://localhost"), Guid.NewGuid().ToString(), TimeSpan.MaxValue);
        var http     = new MockHttpMessageHandler();
        var agent    = new QueuedAgent(config, new HttpClient(http));
        var requests = new[] { new Request {
                                   Action = "a1"
                               }, new Request {
                                   Action = "a2"
                               } };

        //act
        await agent.PostRequests(requests);

        //assert
        Assert.NotNull(http.Posted);
    }
Ejemplo n.º 3
0
    public async Task SuccessDoesNotLogWarning()
    {
        //arrange
        var config        = new ServerConfig(new Uri("http://localhost/"), Guid.NewGuid().ToString());
        var http          = new MockHttpMessageHandler();
        var loggerFactory = Substitute.For <ILoggerFactory>();
        var logger        = new MockLogger();

        loggerFactory.CreateLogger(Arg.Any <string>()).Returns(logger);
        var agent = new QueuedAgent(config, new HttpClient(http), loggerFactory);

        //act
        await agent.PostRequests(new [] { new Request() });

        //assert
        var log = logger.Output.ToString();

        Assert.DoesNotContain("Warning:", log);
    }
Ejemplo n.º 4
0
    public async Task PostContentContainsAllRequests()
    {
        //arrange
        var config     = new ServerConfig(new Uri("http://localhost"), Guid.NewGuid().ToString(), TimeSpan.MaxValue);
        var http       = new MockHttpMessageHandler();
        var httpClient = new HttpClient(http);
        var agent      = new QueuedAgent(config, httpClient);

        //act
        var requests = new[] { new Request {
                                   Action = "a1"
                               }, new Request {
                                   Action = "a2"
                               } };
        await agent.PostRequests(requests);

        //assert
        var actions = JsonSerializer.Deserialize <IEnumerable <Request> >(await http.Posted !.ReadAsStringAsync()) !.Select(t => t.Action).ToList();

        Assert.Contains("a1", actions);
        Assert.Contains("a2", actions);
    }