Обновить
102
0.2
Роман Смирнов@Source

Head of Elixir at Ecom.tech

Отправить сообщение
Интересно, какие бы Вы назвали, хоть пару.

Смещение цели (Вы это ниже описали). Цель разработки — код проекта, а цель TDD — тесты.
При разработке прототипа проекта выполняется двойной объём работы: нужно постоянно менять не только код, но и тесты, что при хорошем покрытии весьма неприятно. Программистам свойственно забывать, что на уровне маркетинга тоже идёт своё проектирование и переделать поведение половины методов из-за изменившихся требований — это вполне рабочая ситуация.
Про ложное ощущение надежности я уже писал. Но стоит повторить, т.к. если, понадеявшись на TDD, сократить отдел тестирования, то можно нехило проблем огрести.
Тесты сами по себе не гарантируют хороший код. Я такие тесты видел, которые в рамках TDD писались, что охренеть можно… На них на самих тесты надо было бы писать.


Вопрос то в другом: улучшает ли TDD качество кода или нет?

Сама по себе — не улучшает. TDD может способствовать улучшению кода, если пришлась по душе конкретному программисту. В противном случае — будет соблюдаться формально, что в целом негативно скажется на проекте.


есть ли возможность в любой момент в течении секунд-минут получить тот единственный достоверный бит «работает ли код так, как надо?»

TDD тут ничем не поможет, на этот вопрос только приёмочное тестирование отвечает. И я ни разу не видел, чтобы это было в виде бита. Хорошие тестировщики всегда, как минимум, минорные недочёты находят. QA — это Вам не TDD, там реальный хардкор )))


А как иначе проверить работает ли код как надо, кроме как проверить его?

Только приёмочное тестирование согласно спецификации. К сожалению, TDD тут ничем не поможет, т.к. юнит-тесты пишет тот же человек, что и код и если он что-то неверно понял, то ошибка будет и в коде и в тестах.


Перед программером новая либа, её нужно заюзать.

В документации по-хорошему тоже есть примеры кода, которые можно тоже автоматически тестировать, чтобы гарантировать актуальность.
Так что я лично за то, чтобы смотреть в нормальную документацию. И только в запущенных случаях — в тесты/код.


Цель — это тест (в терминах TDD).

В терминах TDD — да, в терминах TLD — нет. Этим они и отличаются :-)


Ну я понял. 20% кода работает, а остальные 80% — глючат

С какой стати Вы отождествляете покрытие тестами и надёжность кода? При том, что это очевидно несвязанные вещи. О том, какая часть кода глючит Вам сообщит багтрекинг, а не тесты. Причём он Вам об этом сообщит даже если тестов написать в 10 раз больше, чем основного кода. Потому что тесты всегда будут врать, говоря что всё супер. И с другой стороны, даже если не написать ни одного теста, 80% кода глючить не будут даже если автор — зелёный джуниор.

Эх, увидев оглавление, я сначала подумал, что это подборка более развёрнутых статей на соответствующие темы. А тут как-то по верхам и местами даже мимо кассы.

Пойду я и дальше предлагать бухгалтерский учёт с арефмометром

Я имел в виду, что не придётся учить, потому что человек сам без труда освоит то, появление чего он давно ожидал. Хоть Вы и пишете про стремительную смену технологий, она не столь стремительна как человеческие ожидания.


И если закон Гука гласит, что сила пропорциональна коэффициенту упругости и реальные эксперименты (та самая практика) происходят в русле этой закономерности — то это истина

Вы уже в демагогию перешли… Экспериментальная проверка и практика какой-то промышленной деятельности — это совершенно разные вещи.
Т.е. это не та самая практика (если я программирую на X и много вакансий на Х, то X — это самая идеальная технология), о которой Вы изначально говорили.


жёлто-прессовым журналистам, профессиональная работа и рост которых как раз и основана на разжёвывании Питов и Джоулей этих :)

Даже они эту информацию всего лишь используют как объект для применения своих проф.навыков. А сами их навыки от кол-ва и содержания этой информации никак не зависят.


зачем так долго изучать вот всё-всё-всё подробненько, если для достижения своих целей хватает куда меньшего объёма инфы?

Вот! Теперь Вы гораздо больше похожи на маркетолога типичных курсов. Разумеется у них нет и не может быть цели подготовить профессионалов. У них цель — как можно больше учеников зазвать на волне интереса к программированию. А для этого придётся активно ездить по ушам. "каждый сможет научиться всего за 2 месяца/недели/дня ..."


Как же так получилось, что знали, но не предупредили?

Хз. Не могу тут по существу ничего сказать. Возможно, текущим ВУЗам в программе как раз не хватает "мостика" между концепциями и их практическим применением в мейнстриме.

Бабушка говорит внучку: «не суй пальцы в розетку — будет бобо».

Не думаю, что люди жаждат прогнозов такого уровня )))
Наоборот, они хотят точных прогнозов там, где нет чётких закономерностей.


Это именно новый подход в программировании (кажись, его в 90-хх изобрели), который решает множество проблем.

Ах, вот Вы куда вели… Безусловно, TDD — концепция, которая достойна ознакомления с ней. Но идеализировать её я бы не стал, проблем она тоже привносит немало, особенно когда применяется формально, что тоже не редкость.


А остальной код может глючить безбожно %)

Вы верны себе в манере передёргивать. Во-первых, есть принцип Парето, который в реальной разработке просто замечательно применяется, позволяя не сливать усилия, куда не надо. Во-вторых, отсутствие тестов не означает автоматическое наличие глюков. В-третьих, юнит-тесты не являются заменой ни приёмочному тестированию (которое впрочем можно частично автоматизировать, но это уже к TDD никаким боком не относится), ни документации. В-четвёртых, Вы с таким презрением пишете про "читать код", как-будто тесты это не код и как-будто в них самих не бывает багов )))
Строго говоря, 100% покрытие может нанести самый внушительный удар по проекту, если у разработчиков возникнет иллюзия, что если тесты проходят — то всё гарантировано работает как надо. По факту, так бывает только в книжках и в волшебных мирах, где единороги бегают по радугам.


А TLD — это, по сути, та же TDD с чуть ухудшенной техникой.

Не согласен. Подход совершенно иной. Ухудшенным он будет только для начинающих программистов. Впрочем да, это уже оффтопик.

Я ещё раз отмечу, что у меня нет студентов. Но я не вижу тут проблемы, мы ведь изначально школу обсуждали… Т.е. не предполагалось, что люди поголовно будут программистами и после изучения концепций сразу пойдут трудоустраиваться. А на уровне ВУЗов и ПТУ вполне можно рассмотреть как изученные в школе концепции выражены в популярных на текущий момент языках. Со знанием концепций можно влёгкую учить по языку за семестр без напряга и достаточно глубоко для трудоустройства и даже параллельно с какими-нибудь сложными концепциями, которые на уровень школы не прошли.

Но это противоречит многому, что Вы говорите о новом (что оно почти всё мусор).

В чём противоречие то? Очевидно, что "Почти всё" != "Всё".
Конечно есть развитие, есть новые знания и концепции. К сожалению, их концентрация в общем потоке информации снижается, тут не поспоришь.


Вам, как преподавателю, конечно же, вобщем, всё равно чему учить

С чего Вы взяли, что я преподаватель? Я же уже выше даже явно писал, что это так. Я занимаюсь вполне себе production разработкой веб-проектов.


Но уже на момент обучения нужно было знать не это, чтоб зарабатывать в проектировании радиоэлектроники, а какая китайская микруха что может, сколько стоит, где и в каких объёмах её можно достать.

Надеюсь, закон Ома и правила Кирхгофа от этого не пострадали? )))


Научный прогресс — очень плохо прогнозируется

Ну, так не интересно… Т.е. не ждать мне квантовый компьютер за $1000 через 5 лет, исходя из закона времени? :-D


Сколько лет понадобилось, чтобы набрать аудиторию в 50 млн

И дальше сравнение абсолютно разных технологий в разные эпохи. Даже без поправки на общее население планеты в тот период. К примеру, на момент изобретения телевидения людей в принципе на Земле было в 3 раза меньше, чем на момент изобретения интернета. Вот уж точно рукалицо. Где же Ваше критическое мышление?


К-во инет устройств

И что? Если Вы намекаете на экспоненциальный рост, то его там нет. Кол-во устройств на Земле в принципе весьма конечно и скоро уже нечего будет подключать к интернету )))

Я пишу, что жизненноважные технологии обновляются теперь по нескольку раз за период активной жизни.

Ok. Я вижу, что Вы это пишете. Но я не вижу, чтобы это по факту происходило. Возможно, дело в том, что я физик по образованию, поэтому там где Вы видете бешенный технологический прогресс, я вижу просто шлифовку тех.процессов. Это круто само по себе и заметно в повседневной жизни, но это не сильно влияет на объём знаний по физике, вот даже не то, что не удвоился за предыдущие 20 лет… он даже на 10% не прирос.


И как прикажете научить тому, что будет изобретено только через несколько лет?

Тут есть 2 варианта: либо человек знает концепции, тогда новые изобретения будут для него долгожданным воплощением ожидаемого;
либо не знает и тогда они будут для него своеобразным шоком. В-первом случае даже учить не придётся, во-втором человек скорее всего будет отвергать новые технологии насколько хватит упорства.


Но Ваша то, видимо, сама объективность? ;)

Нет конечно. Именно поэтому практика не является и не может являться критерием истины.


Люди — все субъективны, и в состоянии познать лишь какую-то конечную часть безконечной Вселенной. Так что, все люди всегда ограничены. Не ограничен — только Надмирная Реальность (Создатель).

Ох, куда Вас занесло… Во-первых, исходя из наблюдаемых явлений, Вселенная не бесконечна. А её расширение происходит подобно тому, как расширяется поверхность воздушного шарика при надувании.
Во-вторых, рекомендую почитать про теорию голографической Вселенной. Пополните свой арсенал физических концепций ;-)


И тут я говорю именно о знаниях, а не об информации.

А в чём разница?

Информация может вообще не нести знания или нести мимолётное знание (аля как там дела у Питта с Джоли). Т.е. информация может быть пустой с точки зрения профессионального, духовного и вообще какого-либо развития.


Вы думаете, что первым придумали, что если изучить что-то самое лучшее — это это будет лучше всего?

Нет конечно. Я вроде на новаторство в этом вопросе и не претендовал.


то что, все эти тонны курсов по программированию в мире (включая учебные заведения) либо не хотят денег, либо

Я где-то выше по комментам давал оценку этого объёма знаний — 7 лет. Так и представляю рекламу "приходите на наши 7-летние курсы".
Что касается ВУЗов, то некоторые всё-таки стараются обучать именно концепциям, но там свои сложности… Нужно чтобы преподаватели и хорошо владели материалом и имели желание донести его до широких масс, при этом практически без финансовой компенсации. Ну и студентов надо суметь заинтересовать, они то падки на сиюминутные тренды и зачастую только спустя много лет осознают, что вот те лекции надо было внимательно слушать.

Хорошо. Но как понять: где шум, а где полезная информация?

Критическое мышление + знание существующих концепций и фундаментальных законов.
Более детально ответ зависит от конкретики: на какую тему информация, какого она характера и т.д.


Потоянно учиться всю жизнь, чтоб быть просто актуальным специалистом — такой необходимости не было ещё до средины 20-го века.

В том то и фишка, что такой необходимости и сейчас нет.
Сейчас просто модно стало хватать по верхам, ничего толком не изучив, от этого складывается иллюзия постоянных изменений, хотя по факту они носят чисто косметический характер в абсолютном большинстве случаев.


«Всего лишь» частота обновления социально значимых технологий теперь стала выше частоты обновления поколений.

Предлагаю на примере квантовых компьютеров и помониторить насколько увеличился темп… Сейчас они находятся примерно на той стадии развития, на которой современные компьютеры были в 1950-х годах. Они большие, очень дорогие и пока не особо мощные. Потенциал ускорения — 10^300 раз.
Какие Ваши прогнозы, сколько лет займёт переход к всеобщей доступности? У обычных компьютеров он занял в районе 50 лет.
Вы утверждаете, что частота обновления технологий увеличилась… Но на сколько процентов или во сколько раз по сравнению с серединой XX века?

Желание знать будущее — это как раз и есть попытка какой ни на есть самостоятельности

Ну как сказать… Верить в то, что твоё будущее не зависит от тебя (т.е. теоретически предсказуемо извне) — это скорее фатализм.


Я не упоминал TLD. Речь была именно о первом.

Тогда возможно я не понял суть вопроса. Уточните, пожалуйста.
В целом я за то, чтобы внутренний API имел низкую связность (и как следствие был тестопригоден) и хотя бы 20% наиболее частых/важных функций были покрыты тестами.

Разве что что-то концептуальное, типа единая утилита для управления всем — mix вместо bundler и rake. И plug напоминает rack.
Но в плане деталей и реализации языки совершенно разные. А фреймворки скорее вообще противоположные по идеологии.

Хех, ну хоть какое-то обсуждение… может Вы для этого лишние хабы и добавляете :-)

Лично мою ленту Вы не спамите, т.к. я на все 5 хабов подписан. Но я понимаю недовольство, которое Вам в комментариях к каждой статье высказывают по поводу неуместности хабов Ruby/RoR. На основании 2 лет программирования на Elixir, я могу сказать, что строить параллели с Ruby — это самое вредное при изучении Elixir. В этом плане Вы и себе палки в колеса вставляете и всем, кто поверит в то, что эти языки похожи.
P.S. Если Вам так хочется хаб Ruby к статье, то можно Elixir is not Ruby перевести, он там хоть упоминается ;-)

Хорошо, что лично Вам не помешает.
С Erlang/OTP всё-таки есть прямая связь: Elixir код выполняется на виртуальной машине Erlang, половина его stdlib — обертки над stdlib Erlang, любое приложение на Elixir использует OTP, а Phoenix так вообще очень плотно на OTP опирается.
Что касается Ruby, то связь только такая: на обоих языках приятно программировать и автор Elixir имеет богатый опыт программирования на Ruby. Всё, на этом полезные параллели между Elixir и Ruby заканчиваются.

Во-первых, далеко не любая… Во-вторых, это хоть и популярное, но заблуждение. По-факту, что языки, что фреймворки придерживаются совершенно разных идеологий. И любые ассоциации на тему похожести скорее навредят Вам при изучении Elixir и Phoenix, чем помогут. Хотите ассоциаций — сравнивайте с Erlang и CommonLisp.

Как автор перевода Вы вольны делать что хотите. Но если прикрываетесь сообществом, то не позорьте его.


Ну а о том, что бесплатные переводы по схожей Ruby тематике разжигают какую-либо ненависть, я вообще отказываюсь комментировать.

Не ненависть, а неприятие… Или Вам лично нравится получать спам? Те, кому интересен Elixir подпишутся на Erlang/OTP (пока нет более подходящего хаба)

Хоть я Вас не минусую, но соглашусь с Fedcomp… Это тупо неуважение к Ruby-сообществу и печально, что Вы при этом прикрываетесь Elixir-сообществом, разжигая неприятие.

Это ведь поэтому наш бизнес не в состоянии конкурировать с общемировым?

Почему именно наш? Это по всему миру так, за редким исключением.
Даже Google решила, что им проще урезанный ЯП разработать, чем в квалификацию программистов вкладываться.


Почему проблема у бизнеса, а решать ее должно образование?

Так забота о населении — это вроде как задача государства, а для бизнеса эта задача в десятом ряду. Поэтому бизнес в среднем исходит из сиюминутных реалий.

Трудовому то народу нужны вполне практичные прогнозы.

"Ну что сказать… Устроены так люди… желают знать что будет"
Только если кабинетные науки хоть какие-то вероятностные прогнозы позволяют делать, то точные прогнозы от гадалок — это совсем другая история. Вообще, это косяк… вместо того, чтобы взять на себя ответственность за будущее, люди постоянно пытаются её на кого-то переложить.


А как насчёт TDD?
Вы «за» или «против»? Что думаете?

TDD vs TLD — это чисто субъективный вопрос. Как писал сам Кент Бек — ему удобно TDD, но это не значит, что все обязаны делать именно так.
На начальном этапе TDD полезнее, т.к. насильно помогает продумывать внутренний API, но для опытных программистов эта часть пользы уходит в ноль. Поэтому если кому-то нравится писать тесты постфактум — я нисколько не возражаю.

А потому стоит громадный вопрос: как лучше всего себя вести в таком состоянии?

Лучше всего игнорировать информационный шум. Это само по себе непросто в крупном городе, но я не понимаю вашего драматизма. Общество всегда пребывает в состоянии, в котором оно никогда до этого не пребывало. Но при этом всегда можно и что-то общее с прошлым найти (спираль истории).


В том числе уметь выявить в этом потоке где полезное, а где мусор

Я об этом с самого начала топика пишу. Что надо обучать полезному (концептуальному и неизменному), чтобы фильтры с детства настраивались… А Вы изначально за мейнстрим/моду/мусор агитировали.


Практика — критерий истины.

С чего вдруг? Исходя из практики можно сделать вывод, что Солнце крутится вокруг Земли и вполне спокойно с этим жить и много лет обходиться без гелиоцентрической системы.
Так же и PHP-программист, клепающий сайты визитки, вполне может, опираясь на свою личную практику, делать вывод, что другие языки в вебе вообще не нужны. Точно так же и Ваша практика ограничивает ваши представления об истине.


И что? От этого программы стали хуже?

Даже не сомневайтесь. Дело не в том, чтобы знать названия, а в том, чтобы понимать концепции, стоящие за этими названиями. Будет ошибкой полагать, что Вы неосознанно использовали концепции ФП, и единственная проблема — незнание названий… Проблема в том, что в силу своего незнания Вы не можете оценить практическую пользу знаний, которыми пока не обладаете. Людям вообще свойственно отстаивать именно свой круг знаний, т.к. нам обычно неприятно признаваться в незнании. Но тут ещё больший парадокс, чем больше знаешь, тем больше осознаёшь масштабы неизвестного. И тут я говорю именно о знаниях, а не об информации.


А потом — клац, и квантовые компьютеры закрывают их часть и открывают другие — и снова учиться.

Такие повороты не исключены. Но тем интереснее, хоть какая-то движуха по существу, а не по синтаксису.


Вертолёт тоже был описан задолго до того, как техника доросла до практической реализации.

OMFG, Вы всерьёз считаете, что event loop и promises впервые появились в JavaScript?


И что ж это за путь?

Осознать, что мейнстрим крайне медлительно заимствует концепции, которые давным давно сформулированы и реализованы в чуть менее популярных языках. Изучить эти концепции и спокойно наслаждаться конкурентным преимуществом в ближайшие 50 лет :-)

Но почему-то, именно прибыль — главная цель любой коммерческой деятельности

Если почитать биографии известных миллионеров, то окажется, что это не совсем так.


А людей всегда, всю дорогу интересовали вопросы прогнозируемости последствий от деятельности или бездействия в тех или иных ситуациях.

Это да, поэтому астрология и хиромантия гораздо популярнее любой теории познания..

Информация

В рейтинге
3 147-й
Откуда
Россия
Работает в
Зарегистрирован
Активность