示例#1
0
        static void Main(string[] args)
        {
            var amqpUrl     = "amqp://localhost:5672"; //AMQP URL for RabbitMQ server
            var serviceName = "samba";                 //The unique identifier for the target service

            var msgMapper = new BasicMessageMapper(amqpUrl, serviceName);

            RestBusClient client = new RestBusClient(msgMapper);

            RequestOptions requestOptions = null;

            /*
             * //Uncomment this section to get a response in JSON format (necessary when calling ServiceStack servers)
             *
             * requestOptions = new RequestOptions();
             * requestOptions.Headers.Add("Accept", "application/json");
             */

            var response = SendMessage(client, requestOptions).Result;

            //Display response
            Console.WriteLine(response.StatusCode);
            Console.WriteLine(response.Content.ReadAsStringAsync().Result);

            client.Dispose();
            Console.ReadKey();
        }
示例#2
0
        private async static Task <System.Net.Http.HttpResponseMessage> SendMessage(RestBusClient client, RequestOptions requestOptions)
        {
            //Send Request
            var uri = "api/values"; //Substitute "hello/random" for the ServiceStack self-hosted example and "api/hello/random" for the ServiceStack ASP.Net hosted example

            return(await client.GetAsync(uri, requestOptions));
        }
示例#3
0
        public static void Run(int iterations)
        {
            /*
             * An example that performs a speed test via the RestBus RabbitMQ client.
             *
             * For more examples, see the https://github.com/tenor/RestBus.Examples repo
             *
             */

            BasicMessageMapper msgMapper = new BasicMessageMapper("amqp://localhost:5672", "test");
            RestBusClient      client    = new RestBusClient(msgMapper);

            var msg = new System.Net.Http.HttpRequestMessage(System.Net.Http.HttpMethod.Post, "api/hello/random")
            {
                Content = new System.Net.Http.StringContent("{\"Val\":10}", new UTF8Encoding(), "application/json")
            };

            msg.Headers.Add("Accept", "application/json, text/javascript, */*; q=0.01, */*; q=0.01");

            Stopwatch watch = new Stopwatch();

            HttpResponseMessage res;

            watch.Start();
            for (int i = 0; i < iterations; i++)
            {
                res = client.SendAsync(msg, System.Threading.CancellationToken.None).Result;
            }

            watch.Stop();

            Console.WriteLine("Elapsed time: " + watch.Elapsed);
            client.Dispose();
            Console.ReadKey();
        }
示例#4
0
        public static void Run()
        {
            /*
             * An example that composes a HttpRequest Message and sends it via the RestBus RabbitMQ client.
             *
             * For more examples, see the https://github.com/tenor/RestBus.Examples repo
             *
             */

            BasicMessageMapper msgMapper = new BasicMessageMapper("amqp://localhost:5672", "test");
            RestBusClient      client    = new RestBusClient(msgMapper);

            var msg = new System.Net.Http.HttpRequestMessage(System.Net.Http.HttpMethod.Post, "/test/my_api")
            {
                Content = new System.Net.Http.StringContent("{\"Val\":10}", new UTF8Encoding(), "application/json")
            };

            msg.Headers.Add("Accept", "application/json, text/javascript, */*; q=0.01, */*; q=0.01");

            var res = client.SendAsync(msg, System.Threading.CancellationToken.None).Result;


            Console.ReadKey();
            client.Dispose();
        }
示例#5
0
        public async static void Run(int iterations)
        {
            /*
             * An example that performs a speed test via the RestBus RabbitMQ client.
             *
             * For more examples, see the https://github.com/tenor/RestBus.Examples repo
             * For more elaborate speed tests see the https://github.com/tenor/RestBus.Benchmarks repo
             *
             */

            //Start Web API 2 host to receive messages.
            WebAPISelfHost host    = new WebAPISelfHost();
            var            servers = host.Start();

            //Create client
            BasicMessageMapper msgMapper = new BasicMessageMapper(ConfigurationManager.AppSettings["rabbitmqserver"], "test");
            RestBusClient      client    = new RestBusClient(msgMapper);

            //Compose message
            var msg = new System.Net.Http.HttpRequestMessage(System.Net.Http.HttpMethod.Post, "api/test/random")
            {
                Content = new System.Net.Http.StringContent("{\"Val\":10}", new UTF8Encoding(), "application/json")
            };

            msg.Headers.Add("Accept", "application/json, text/javascript, */*; q=0.01, */*; q=0.01");

            Stopwatch watch = new Stopwatch();

            HttpResponseMessage res;

            watch.Start();
            for (int i = 0; i < iterations; i++)
            {
                //Send message
                res = await client.SendAsync(msg, System.Threading.CancellationToken.None);
            }

            watch.Stop();

            Console.WriteLine("Elapsed time: " + watch.Elapsed);
            Console.ReadKey();

            //Dispose client
            client.Dispose();
            //Dispose servers
            foreach (var server in servers)
            {
                server.Dispose();
            }
        }
示例#6
0
        void Application_Start(object sender, EventArgs e)
        {
            // Code that runs on application startup
            BundleConfig.RegisterBundles(BundleTable.Bundles);
            AuthConfig.RegisterOpenAuth();
            RouteConfig.RegisterRoutes(RouteTable.Routes);

            //Init RestBus client
            var amqpUrl     = "amqp://localhost:5672"; //AMQP URL for RabbitMQ installation
            var serviceName = "samba";                 //The unique identifier for the target service

            var msgMapper = new BasicMessageMapper(amqpUrl, serviceName);

            HelloServiceClient = new RestBusClient(msgMapper);
        }
示例#7
0
        static void Main(string[] args)
        {
            int  iterationsPerTask = Int32.Parse(ConfigurationManager.AppSettings["MessagesPerThread"]);
            int  taskCount         = Int32.Parse(ConfigurationManager.AppSettings["NoOfThreads"]);
            bool expectReply       = Boolean.Parse(ConfigurationManager.AppSettings["ExpectReply"]);

            var amqpUrl     = ConfigurationManager.AppSettings["ServerUri"]; //AMQP URI for RabbitMQ server
            var serviceName = "speedtest";                                   //Uniquely identifies this service

            var msgMapper  = expectReply ? new BasicMessageMapper(amqpUrl, serviceName) : new SendOnlyMessageMapper(amqpUrl, serviceName);
            var subscriber = new RestBusSubscriber(msgMapper);

            var client = new RestBusClient(msgMapper);

            Task[] tasks = new Task[taskCount];
            for (int t = 0; t < taskCount; t++)
            {
                tasks[t] = new Task(() =>
                {
                    Message msg;
                    for (int i = 0; i < iterationsPerTask; i++)
                    {
                        msg = new Message {
                            Body = BodyGenerator.GetNext()
                        };
                        var res = client.PostAsJsonAsync("api/test/", msg, null).Result;
                    }
                }, TaskCreationOptions.LongRunning);
            }

            Console.WriteLine("Sending " + iterationsPerTask * taskCount + " messages across " + taskCount + " threads");
            Stopwatch watch = new Stopwatch();

            watch.Start();
            for (int t = 0; t < taskCount; t++)
            {
                tasks[t].Start();
            }

            Task.WaitAll(tasks);

            watch.Stop();
            Console.WriteLine("Total time: " + watch.Elapsed);
            Console.ReadKey();
            client.Dispose();
        }
示例#8
0
文件: Basic.cs 项目: tuga1975/RestBus
        public async static void Run()
        {
            /*
             * An example that composes a HttpRequest Message and sends it via the RestBus RabbitMQ client.
             *
             * For more examples, see the https://github.com/tenor/RestBus.Examples repo
             *
             */

            //Start Web API 2 host to receive message.
            WebAPISelfHost host    = new WebAPISelfHost();
            var            servers = host.Start();

            //Create client
            BasicMessageMapper msgMapper = new BasicMessageMapper("amqp://localhost:5672", "test");
            //msgMapper = new QueueingMessageMapper("amqp://localhost:5672", "test"); //Uncomment this to only queue messages.

            RestBusClient client = new RestBusClient(msgMapper);

            //Compose message
            var msg = new System.Net.Http.HttpRequestMessage(System.Net.Http.HttpMethod.Post, "/api/test")
            {
                Content = new System.Net.Http.StringContent("{\"Val\":10}", new UTF8Encoding(), "application/json")
            };

            msg.Headers.Add("Accept", "application/json, text/javascript, */*; q=0.01, */*; q=0.01");

            //Send message
            Console.WriteLine("Sending Message ...");

            var res = await client.SendAsync(msg, System.Threading.CancellationToken.None);

            Console.WriteLine("Response Received:\n{0}\nContent:\n{1}\n", res, Encoding.UTF8.GetString((res.Content as ByteArrayContent).ReadAsByteArrayAsync().Result));

            Console.WriteLine("Press any key to quit.");
            Console.ReadKey();

            //Dispose client
            client.Dispose();
            //Dispose servers
            foreach (var server in servers)
            {
                server.Dispose();
            }
        }
        public async Task FrontOfficeKPlusTradeSaveTest()
        {
            // Arrange
            var amqpUrlcli     = "amqp://localhost:5672"; //AMQP URL for RabbitMQ installation
            var serviceNamecli = "tradeSaver";            //The unique identifier for the target service

            var msgMappercli = new BasicMessageMapper(amqpUrlcli, serviceNamecli);

            using (var client = new RestBusClient(msgMappercli))
            {
                JObject oJsonObject = new JObject();
                oJsonObject.Add("SourceApplication", "KPlus");
                oJsonObject.Add("Portfolio", "ref123");
                oJsonObject.Add("CounterParty", "abcd");
                oJsonObject.Add("Id", "WAY-111118");
                oJsonObject.Add("Owner", "MUBE");
                oJsonObject.Add("BookingDate", DateTime.Today.ToShortDateString());
                oJsonObject.Add("ValueDate", DateTime.Today.ToShortDateString());
                oJsonObject.Add("MaturityDate", DateTime.Today.ToShortDateString());

                RequestOptions requestOptions = null;

                //Uncomment this section to get a response in JSON format

                requestOptions = new RequestOptions();
                requestOptions.Headers.Add("Accept", "application/json");


                //Send Request
                var busresponse = client.PostAsync(baseAddress + "api/trades", new StringContent(oJsonObject.ToString(), Encoding.UTF8, "application/json")).Result;

                //Display response
                Assert.AreEqual("OK", busresponse.StatusCode.ToString());
                Console.WriteLine(busresponse.Content.ReadAsStringAsync().Result);

                //Assert Response
                var result = busresponse.Content.ReadAsStringAsync().Result;
                Assert.AreEqual(true, result.Contains("WAY"));
            }
        }
        public async Task FrontOfficeKPlusTradeLoadTest()
        {
            string baseLoadAddress = "http://localhost:8000/";
            var    amqpUrlcli      = "amqp://localhost:5672"; //AMQP URL for RabbitMQ installation
            var    serviceNamecli  = "trades";                //The unique identifier for the target service

            var msgMappercli = new BasicMessageMapper(amqpUrlcli, serviceNamecli);

            using (var busClient = new RestBusClient(msgMappercli))
            {
                JObject oJsonObject = new JObject();
                oJsonObject.Add("source", "KPlus");
                oJsonObject.Add("tradeids", "1234,12345");
                oJsonObject.Add("fields", "ID,Portfolio,CounterParty");

                RequestOptions requestOptions = null;

                //Uncomment this section to get a response in JSON format

                requestOptions = new RequestOptions();
                requestOptions.Headers.Add("Accept", "application/json");


                //Send Request
                var busresponse = busClient.PostAsync(baseLoadAddress + "api/tradeloader", new StringContent(oJsonObject.ToString(), Encoding.UTF8, "application/json")).Result;

                //Display response
                Console.WriteLine(busresponse.StatusCode);
                Console.WriteLine(busresponse.Content.ReadAsStringAsync().Result);

                //Assert response
                var result = busresponse.Content.ReadAsStringAsync().Result;
                TradeLoaderResponse tmp = JsonConvert.DeserializeObject <TradeLoaderResponse>(result);
                Assert.AreEqual(2, tmp.Trades.Count());
                Assert.AreEqual("1234", tmp.Trades.ToList()[0].Id);
            }
        }
示例#11
0
 protected RequestOptions GetRequestOptions(HttpRequestMessage request)
 {
     return(RestBusClient.GetRequestOptions(request));
 }