public void TestSgipLifetimeSimple()
        {
            var client = new SgipSmsClient(_configurations);

            Task.Run(async() =>
            {
                await client.StartAsync();
                await Task.Delay(5000);
                await client.StopAsync();
            }).Wait();
        }
Exemple #2
0
        public void TestLifetimeServer()
        {
            SmsServerConfigurations configs1 = new SmsServerConfigurations()
            {
                HostName  = "127.0.0.1",
                HostPort  = 12321,
                UserName  = "******",
                Password  = "******",
                ServiceID = "99999"
            };

            SgipConfigurations configs2 = new SgipConfigurations()
            {
                HostName  = configs1.HostName,
                HostPort  = configs1.HostPort,
                UserName  = configs1.UserName,
                Password  = configs1.Password,
                ServiceId = configs1.ServiceID
            };

            InternalSgipSmsServer server = new InternalSgipSmsServer(configs1);
            SgipSmsClient         client = new SgipSmsClient(configs2);


            var t1 = server.StartAsync(); t1.Wait();
            var t2 = client.StartAsync(); t2.Wait();

            bool isConnected = (client.Status == SmsClientStatus.Connected);

            Debug.WriteLine("Waiting...");

            var tw = Task.Delay(10000); tw.Wait();

            var t11 = client.StopAsync(); t11.Wait();
            var t12 = server.StopAsync(); t12.Wait();

            Assert.IsTrue(isConnected);
        }
Exemple #3
0
        private static void TestSgipChannel()
        {
            var configs = new SgipConfigurations()
            {
                HostName       = "127.0.0.1",
                ListenHostName = "127.0.0.1",
                HostPort       = 8801,
                ListenPort     = 8802,
                UserName       = "******",
                Password       = "******",
                ServiceId      = "3010099999",
                CorporationId  = "99999",
                KeepConnection = false
            };

            //configs = new SgipConfigurations()
            //{
            //    HostName = "220.201.8.97",
            //    HostPort = 9001,
            //    ListenPort = 8822,
            //    UserName = "******",
            //    Password = "******",
            //    ServiceId = "10655024033",
            //    CorporationId = "31850",
            //    ServiceType="9991800181",
            //    KeepConnection = false,
            //};


            var receiver = Program.GetArgumentValue("no");
            var content  = Program.GetArgumentValue("text");

            if (string.IsNullOrEmpty(receiver))
            {
                receiver = "18613350979";
            }
            if (string.IsNullOrEmpty(content))
            {
                content = "【天天快递】明天下雨,请记得带伞。";
            }

            Console.WriteLine("sending \"{0}\" to {1}...", content, receiver);

            var t = Task.Run(async() =>
            {
                var client = new SgipSmsClient(configs);
                await client.StartAsync();

                client.SmsResponseReceived += (sender, e) =>
                {
                    var response = e.Envolope.Response as SgipMessageSubmitResponse;
                    Console.WriteLine("<!> RESPONSE: " + response.Result.ToString());
                };

                client.SmsReportReceived += (sender, e) =>
                {
                    var report = e.Report as SgipMessageReport;
                    Console.WriteLine("<!> REPORT: " + report.State.ToString());
                };

                await client.SendSmsAsync(receiver, content);
            });

            try
            {
                t.Wait();
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.ToString());
            }

            int count = 60;

            while (count > 0)
            {
                count--;
                Console.Title = string.Format("waiting {0}...", count);
                Task.Delay(1000).Wait();
            }
        }
        public void TestSgipSendSmsPerformanceByCount()
        {
            var client = new SgipSmsClient(_configurations);


            var receivers = new string[] { "13979121569" };
            var content   = "测试短信";

            int count = 1000;

            int responseCount = 0;
            int reportCount   = 0;

            Task.Run(async() =>
            {
                client.SmsResponseReceived += (sender, e) =>
                {
                    responseCount++;
                };

                client.SmsReportReceived += (sender, e) =>
                {
                    reportCount++;
                };

                await client.StartAsync();

                var start = DateTime.Now;
                DateTime?responseComplete = null;
                DateTime?reportComplete   = null;

                for (int i = 0; i < count; i++)
                {
                    await client.SendSmsAsync(receivers, content);
                }

                var waitSpan  = TimeSpan.FromSeconds(count / 100.0);
                var waitStart = DateTime.Now;
                while ((DateTime.Now - waitStart) < waitSpan)
                {
                    if (responseComplete == null && responseCount == count)
                    {
                        responseComplete = DateTime.Now;
                    }

                    if (reportComplete == null && reportCount == count)
                    {
                        reportComplete = DateTime.Now;
                    }

                    if (responseCount == count && reportCount == count)
                    {
                        break;
                    }
                    await Task.Delay(50);
                }

                await client.StopAsync();


                if (responseComplete.HasValue)
                {
                    var duration = (responseComplete.Value - start).TotalSeconds;
                    Debug.WriteLine("Submit spent {0} seconds on {1} messages, throughput : {2} mps",
                                    duration, count, count / duration);
                }

                if (reportComplete.HasValue)
                {
                    var duration = (reportComplete.Value - start).TotalSeconds;
                    Debug.WriteLine("Report spent {0} seconds on {1} messages, throughput : {2} mps",
                                    duration, count, count / duration);
                }
            }).Wait();
        }
        public void TestServerSgipSendSmsPerformanceByTime()
        {
            var responses = new ConcurrentDictionary <string, object>();
            var reports   = new ConcurrentDictionary <string, object>();



            var client = new SgipSmsClient(_configurations);

            var server = new SgipSmsServer(new SmsServerConfigurations()
            {
                HostName   = _configurations.HostName,
                HostPort   = _configurations.HostPort,
                ClientPort = _configurations.ListenPort,
                UserName   = _configurations.UserName,
                Password   = _configurations.Password,
                ServiceID  = _configurations.ServiceId,
            });


            var ts1 = server.StartAsync();

            ts1.Wait();


            var receivers = new string[] { "13979121569" };
            var content   = "测试短信";

            var totalSpan = TimeSpan.FromMinutes(5);
            int count     = 0;

            int responseCount = 0;
            int reportCount   = 0;

            Task.Run(async() =>
            {
                client.SmsResponseReceived += (sender, e) =>
                {
                    var response = e.Envolope.Response as SgipMessageSubmitResponse;
                    responseCount++;

                    var id = response.SequenceId;
                    if (responses.ContainsKey(id))
                    {
                        Debugger.Break();
                    }

                    responses[id] = response;
                };

                client.SmsReportReceived += (sender, e) =>
                {
                    var report = e.Report as SgipMessageReport;

                    reports[report.SubmitId] = report;
                    var id = report.SubmitId;

                    var stamp = DateTime.Now;
                    while (!responses.ContainsKey(id) && (DateTime.Now - stamp).TotalSeconds < 100)
                    {
                        Thread.Sleep(100);
                    }
                    if (!responses.ContainsKey(id))
                    {
                        Debug.WriteLine("<!> missing {0}", id);
                    }

                    reportCount++;
                };

                await client.StartAsync();

                var start = DateTime.Now;
                DateTime?responseComplete = null;
                DateTime?reportComplete   = null;

                var updateStamp = DateTime.Now;

                while ((DateTime.Now - start) < totalSpan)
                {
                    await client.SendSmsAsync(receivers, content);
                    count++;
                    await Task.Delay(0);

                    if ((DateTime.Now - updateStamp) >= TimeSpan.FromMinutes(1))
                    {
                        updateStamp = DateTime.Now;
                        Debug.WriteLine("{0} {1} {2} ", count, responseCount, reportCount);
                    }
                }

                var waitSpan  = TimeSpan.FromSeconds(count / 100);
                var waitStart = DateTime.Now;

                while ((DateTime.Now - waitStart) < waitSpan)
                {
                    if ((DateTime.Now - updateStamp) >= TimeSpan.FromMinutes(1))
                    {
                        updateStamp = DateTime.Now;
                        Debug.WriteLine("{0} {1} {2} ", count, responseCount, reportCount);
                    }

                    if (responseComplete == null && responseCount == count)
                    {
                        responseComplete = DateTime.Now;
                    }

                    if (reportComplete == null && reportCount == count)
                    {
                        reportComplete = DateTime.Now;
                    }

                    if (responseCount == count && reportCount == count)
                    {
                        break;
                    }
                    await Task.Delay(50);
                }

                await client.StopAsync();


                Debug.WriteLine("Messages Sent {0}", count);
                Debug.WriteLine("Rsponses {0}", responseCount);
                Debug.WriteLine("Reports  {0}", reportCount);

                if (responseComplete.HasValue)
                {
                    var duration = (responseComplete.Value - start).TotalSeconds;
                    Debug.WriteLine("Submit spent {0} seconds on {1} messages, throughput : {2} mps",
                                    duration, count, count / duration);
                }

                if (reportComplete.HasValue)
                {
                    var duration = (reportComplete.Value - start).TotalSeconds;
                    Debug.WriteLine("Report spent {0} seconds on {1} messages, throughput : {2} mps",
                                    duration, count, count / duration);
                }
            }).Wait();

            var ts2 = server.StopAsync();

            ts2.Wait();

            var stats = server.GetStats();

            Debug.WriteLine("Server stats:\r\n");
            Debug.WriteLine(stats);
        }