К основному контенту

DevCon'12 - как это было

23 и 24 мая в Подмосковье прошел очередной, ставший уже ежегодным, DevCon. Делегации "Кода Безопасности" удалось в нем поучаствовать.
Пару слов об организации. Все было хорошо: загородный свежий воздух, красивое место, хорошо организованное питание и проживание.
Но ехали туда не за этим :)
Ознакомившись с докладами перед отъездом, решил, что схожу на доклады по новой студии, С++ и Windows Phone. Последняя тема привлекла из чисто меркантильных соображений, задумывался на покупкой смартфона на WinPhone. Хотелось понять, что о платформе думают разработчики.

Думаю, что не буду писать отзывы в своем обычном стиле (доклад-докладчик-что полезного). Как то не поперло в этот раз.

Ниже просто вещи, которые показались мне полезными, интересными или просто фан :)

Фишки новой студии (ее RC уже доступен), про которые я раньше не знал:

  1. Code Review (запрос на ревью, возможность оставить комментарии, привязанные непосредственно к строчке кода)
  2. Поиск дубликации. Студия сама находит похожие куски кода, даже если названия переменных отличаются.
Новые возможности отладчика:

  1. Parallel Watch - в точке останова есть возможность посмотреть значения переменных в разных потоках. Неплохо. Осталось неясным можно ли использовать это при просмотре дампов от процессов exe, созданных старыми студиями. Будем смотреть. (см. комментарий Максима Гольдина ниже - должно работать. И вроде действительно работает)
  2. Новый Remote Debugging - автосканирование запущенных Remote Debuging сервисов на тестовых машинах. Дает возможность выбрать из списка куда подключиться и задать креды.
  3. Просмотр полей COM-объектов в Watch с помощью настраивания мапинга через natvis файлы. (И оказывается не только COM:  интересную ссылку прислал Максим Гольдин)


Остальное "Что нового". Но, к сожалению, с учетом проблем с XP (подробности здесь) пользоваться всеми этими плюшками получится нескоро. 
На конференции товарищи из русского Микрософта на вопрос про XP или вообще ничего не могли ответить (были не в курсе проблемы), или "нужна поддержка XP - пишете на старой студии". Ну в общем эта проблема осталась и в RC (что и ожидалось). Update: хорошие новости о поддержке XP с TechEd 2012

На докладе "Яндекс-Карты" про пляски в стиле Tango (Windows Phone 7.5) выяснилось, что товарищам редко удается переиспользовать готовый код из приложений для iOS и Android, что с одной стороны понятно, но с другой стороны между iOS и  Android это удается делать. Все из-за того, что доступа к native нет никакого. Грустно... Думаю СитиГид-а для WinPhone ждать придется долго.

Асинхронность в Windows RT: реализовано на уровне системы. Все операции длиннее 50ms должны делаться асинхронными. Реализация в коде простая и понятная. Неплохо сделали.

Пожалуй выделю доклад Мити Сошникова про обучение детей программированию. Познавательно. Буду пробовать. Начинаем с Kodu Game Lab (ms-kodu.ru). Потом Small Basic.

Пытался выпытать у товарищей из MS подробности будущего Windows Phone после релиза Windows 8. Молчат партизаны. Вернее "все будет хорошо" :) Но ведь так не бывает. После конференции наткнулся на интересную статью на эту тему 

Примеры использования Windows RT API из С++ напрягают. С одной стороны все попрятали и обернули. Но контроля программисту оставили мало. Но ведь это C++!! Зачем?
Кстати еще один интересный линк появившийся после обсуждения доклада по C++. Как раз про возможность контроля.

Одной из новых фишек конференции стало проведение ночи программирования. Правда получилось, имхо, не очень. Из анонса не было понятно, что людям без опыта в WinRT делать там нечего. А пришли как раз такие :). Спасибо С. Пугачеву за небольшой ликбез.

Сергей же выдал интересный доклад про возможности подстройки студии под себя. Будет возможность посмотрите видео (или слайды)

Вот и все. Не густо, не смотря на размах. На Sofware People мне понравилось больше.

Обещанный фан. 
Услышал новые термины:
Дебагирование - это то, что я называю отладка (или дебагинг)
Апликация - приложение (апликуха)
Резолюция - определение (резолвинг)

Комментарии

  1. Максим Гольдин7 июня 2012 г. в 01:07

    Parallel Watch должен работать на dump файлах точно так-же как Watch и Thread окна (даже если файлы созданы предыдущей версией Студии).

    ОтветитьУдалить
  2. Максим, спасибо за комментарий. Как раз вчера поставил RC и проверил дампы. Действительно работает.

    ОтветитьУдалить
  3. Максим Гольдин7 июня 2012 г. в 03:57

    NATVIS файлы могут быть использованы не только для визуализации COM-объектов, но и для обычных объектов (с добавлением всяких интересных прибамбасов :-)). http://blogs.msdn.com/b/mgoldin/archive/2012/06/06/visual-studio-2012-and-debugger-natvis-files-what-can-i-do-with-them.aspx

    ОтветитьУдалить
  4. действительно интересно :) Спасибо за ответы! Надеюсь без обид? ;)

    ОтветитьУдалить
  5. Максим Гольдин7 июня 2012 г. в 22:10

    Обиды? :-) Напротив! Одни благодарности. И за участие в DevCon'12, и за посещение доклада, и за все замечания/комментарии - критика только приветствуется!

    ОтветитьУдалить

Отправить комментарий

Популярные сообщения из этого блога

Полезные ресурсы для молодых (и не только) тестировщиков

сперто(с) Уже 3 месяца провожу собеседования тестировщиков (март 2016). Поначалу они просто  веселили - после 15-летнего опыта собеседования С++-разработчиков, общение с тестировщиками (чаще были "-цы") было чем-то экзотическим и забавным. Потом становилось все грустнее и грустнее, мимими закончилось. Началась печаль.

Mock vs Stub

Когда мы начали изучать модульное тестирование, то одними из первых терминов, с которыми пришлось познакомиться, стали Mock и Stub. Ниже попробуем порассуждать в чем их сходство и различие, как и для чего они применяются. Проверять работоспособность тестируемого объекта (system under test - SUT) можно двумя способами: оценивая состояние объекта или его поведение. В первом случае проверка правильности работы метода SUT заключается в оценке состояния самого SUT, а также взаимодействующих объектов, после вызова этого метода. Во-втором, мы проверяем набор и порядок действий (вызовов методов взаимодействующих объектов, других методов SUT), которое должен совершить метод SUT. Собственно, если коротко, то в одном случае используется Stub, а в другом Mock. Это объекты, которые создаются и используются взамен реальных объектов, с которым взаимодействует SUT в процессе своей работы. Теперь подробнее. Gerard Meszaros использует термин Test Double (дублер), как обозначение для объе

Заметки на коленке - 3. Что еще делать, если ваши тесты уже "зеленые"?

"Lately I find I'm working on automated tests that return non-binary results. Tests that neither pass nor fail" by  @noahsussman Отличная мысль, которую я ретвитил еще в 2016. Но давайте вместе подумаем, что за этим может скрываться? ( кстати, не знаю, что при этом думал Noah ) Ваши тесты прошли и прошли "успешно". Все хорошо или все же есть, куда еще посмотреть? Дальше то, что использовал я лично и то, что еще можно прикрутить дополнительно. Естественно все шаги ниже должны быть автоматизированны. 1. Контролируйте время выполнения тестов. Если набор проверок не меняется (а такое часто бывает, к сожалению), то рост времени выполнения может говорить о проблемах в продакшен коде (чаще всего) или проблемах с окружением. 2. Контроль за количеством выполняемых тестов. "Все зеленое" не значит, что сегодня выполняли те же Х тестов, что и вчера. Смешно(нет), но случается такое, что какие-то проверки "исчезают" из запуска из-за того, что у кого-то &qu