"Рабочая" версия SampleSmartConsole не получает инструмент и портфель


"Рабочая" версия SampleSmartConsole не получает инструмент и портфель
Atom
15.12.2011


Приветствую, недавно закончил курс "Базовый" по S#, пытаюсь довести до ума пример SampleSmartConsole, но выполнение програмы останавливается после сообщения "Дожидаемся появления в программе инструмента RIH и портфеля "
Хотелось бы узнать где ошибка в этом коде и по какому алгоритму самому определять подобные моменты.


Код
using System;
using System.Net;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using StockSharp.Algo;
using StockSharp.BusinessEntities;
using StockSharp.Smart;
using System.Threading;
using Ecng.Collections;
using Ecng.Common;
using StockSharp.Algo.Candles;


namespace MyFirstBot
{

    class Program
    {

        static string login = "Мой логин";
        static string password = "QKVDBU";
        public static Portfolio portfolio;
        public static Security secObject;
        static string sec;
        private StockSharp.Algo.Candles.CandleManager _candleManager;
        private TimeSpan _candleWidth;
        private SmartTrader trader;
        const string secCode = "RIH2";
        const string account = "Мой счет";


        static string ipAddress = "62.141.86.229";
        static System.Net.IPAddress addr = System.Net.IPAddress.Parse(ipAddress);
        static System.Net.IPEndPoint server = new System.Net.IPEndPoint(addr, 8090);

        static void Main()
        {


            try
            {
                var trader = new SmartTrader(login, password, server);
                var waitHandle = new AutoResetEvent(false);
                trader.Connected += () =>
                {
                    Console.WriteLine("Подключение было произведено успешно.");

                   waitHandle.Set();
                };
                Console.WriteLine("Производим подключение...");

                trader.Connect();
   
                waitHandle.WaitOne();


                trader.NewPortfolios += portfolios =>
                {
                    // необходимое условие работы в SmartCOM
                    portfolios.ForEach(trader.RegisterPortfolio);

                    if (portfolio == null)
                    {
                       
                        portfolio = portfolios.FirstOrDefault(p => p.Name == account);

                        if (portfolio != null)
                        {
                            Console.WriteLine("Портфель {0} появился.", account);

                            if (secObject != null)
                                waitHandle.Set();
                        }
                    }
                };

               
                trader.NewSecurities += securities =>
                        {
                            if (secObject == null)
                            {
                                
                                secObject = securities.FirstOrDefault(sec => sec.Code == secCode && sec.Type == SecurityTypes.Equity);

                                if (secObject != null)
                                {
                                    Console.WriteLine("Инструмент RIH2 появился.");

                                    if (portfolio != null)
                                        waitHandle.Set();
                                }
                            }
                        };
                Console.WriteLine("Дожидаемся появления в программе инструмента RIH и портфеля {0}...".Put(account));

                // запускаем экспорт по инструментам и портфелям
                trader.StartExport();

                // дожидаемся появления портфеля и инструмента
                waitHandle.WaitOne();

                trader.SecuritiesChanged += securities =>
                {
                    // если инструмент хоть раз изменился (по нему пришли актуальные данные)
                    if (securities.Contains(secObject))
                        waitHandle.Set();
                };

                Console.WriteLine("Дожидаемся обновления данных по инструменту RIH2...");


                trader.RegisterSecurity(secObject);
                waitHandle.WaitOne();




          }
            catch (Exception ex)
            {
                Console.WriteLine(ex);
                
            }
            Console.ReadKey();
        }
    
    }
}

Теги:


Спасибо:


1 2  >
Mikhail Sukhov

Фотография
Дата: 15.12.2011
Ответить


Что-нибудь еще печатает?
Спасибо:

Андрей Александрович

Фотография
Дата: 15.12.2011
Ответить


Нет больше ничего не происходит. Если вбить данные реального счета и IP боевого сервера то остановка происходит на этой же стадии.
Если заменить в коде waitHandle.WaitOne на скажем Thread.Sleep(5000) чтобы выполнение программы дошло до вывода исключений то в командной строке появляется определенный текст но я не знаю как скопировать его на форум.
Спасибо:

Mikhail Sukhov

Фотография
Дата: 15.12.2011
Ответить


Можете перед

portfolio = portfolios.FirstOrDefault(p => p.Name == account);

вывести на экран все portfolios, которые пришли. По инструменту. А справочник инструментов в СмартТрейде обновлен?
Спасибо:

Андрей Александрович

Фотография
Дата: 16.12.2011
Ответить


Пробовал ставить вывод на экран в разные места кода... Списки обновлены, СмартТрейд подключается к демо серверу без проблем.
При размещении
Код
Console.WriteLine("Инструменты или портфели");  
Console.ReadKey();

в разные места в коде не дает никаких результатов. Причем размещение в тела функций событий появления новых инструментов и новых портфелей этих двух строчек не прерывает программу для нажатия клавиши, следовательно в моем понимании эти события вообще не дергаются...
Михаил, если у вас есть минутка свободного времени, вы не могли бы скопировать этот код к себе в Visual Studio и проверить его работоспособность?
На курсах робота писали под Quik там всё выгружалось нормально а теперь выходит сам я не могу даже к системе подключится толком...
Спасибо:

Mikhail Sukhov

Фотография
Дата: 16.12.2011
Ответить


Просьба актуальна из сообщения http://stocksharp.com/posts/m/14674/
Спасибо:

Андрей Александрович

Фотография
Дата: 16.12.2011
Ответить


Михаил, если у вас работает приведенный выше код, то по какой причине могут не приходить новые инструменты и портфели на моем компьютере? Какая у вас версия SmartCom? Какие еще варианты решения этой проблемы можно попробовать?
Судя по количеству просмотров этой темы с подобными трудностями столкнулся не только я...
Хотелось бы быстрее устранить неполадки, возникшие по неведомым мне причинам, и приступить к написанию алгоритма.
Буду благодарен за помощь...
Спасибо:

Mikhail Sukhov

Фотография
Дата: 16.12.2011
Ответить


Прочите пожалуйста еще раз мое сообщение http://stocksharp.com/posts/m/14674/
Спасибо:

Андрей Александрович

Фотография
Дата: 16.12.2011
Ответить


Я внимательно читаю все ваши сообщения

Eridu Перейти
Пробовал ставить вывод на экран
При размещении
Код
Console.WriteLine("portfolios");  

не дает никаких результатов. Cледовательно в моем понимании эти события вообще не дергаются...


trader.ProcessDataError ничего не выводит.
Пример SampleSmart подключается к демо серверу, но списки инструментов и портфелей пусты.
Спасибо:

Андрей Александрович

Фотография
Дата: 16.12.2011
Ответить


Сейчас протестировал соединение через Smart COM Test Connect. Все портфели и котировки идут в штатном режиме.
Выходит что-то не так в коде...
Спасибо:

Mikhail Sukhov

Фотография
Дата: 16.12.2011
Ответить


Eridu Перейти
Сейчас протестировал соединение через Smart COM Test Connect. Все портфели и котировки идут в штатном режиме.
Выходит что-то не так в коде...


Вы можете ответить еще на этот вопрос http://stocksharp.com/posts/m/14650/ ? Как минимум должно печататься "Производим подключение..."
Спасибо:
1 2  >

Добавить файлы через драг-н-дроп, , или вставить из буфера обмена.

loading
clippy