– А покажи-ка?
– Дык вот же я прямо на кроссе в разрыв и вставил. Усилитель ТЧ (тональной частоты).
Опа, а у нас-то оборудование цифровое!
– Дядь Вась, а какую полосу частот он усиливает?
– ....
– Дядь Вась, вот тебе магарыч. За то, что уберешь свой "усилок".
Конечно же, все заработало. Дядь Васин усилок срезал самый верх несущей частоты модема. И в результате порядка 10% пакетов терялось. Ни одному нашему спецу даже в буйных фантазиях не представлялось, что каким-то образом может вырезаться часть частоты.
#367: Собрать по кирпичику
16 декабря 2008, 16:45. рейтинг: 764
Работал над одним проектом, который до меня делали другие. Проект достаточно большой, и одна из его частей считывает некоторые данные с базы. Есть возможность регулировать дату от и до при считывании. Возникла проблема, из-за которой клиент очень ругался. Если промежуток от и до очень большой, к примеру кто-то захочет считать данные за несколько лет, то скрипт работает нереально медленно, а иногда даже выдаёт таймаут.
Бились над проблемой 3 дня, перелопатили кучу кода, даже нашли некоторые другие баги, которые не имели отношения к проблеме. В итоге наткнулся на кусок кода в том месте, где искать никто просто не додумался:
$res = $DB->getData($query); //считывает данные с ДБ и загоняет в пронумерованный массив
$data = new array();
foreach ($res as $key=>$value)
{
if (!$data[$key])
$data[$key] = $value;
};
Все это вместо простого $data = $res;
Что имел ввиду кодер, родивший это чудо, так и осталось загадкой.
16 декабря 2008, 20:30. рейтинг: 2043
Довелось мне как-то писать для некоей конторы анализатор рабочего времени. Программка бегала по базе системы контроля доступа и считала время прихода/ухода по людям в заданной группе. При этом учитывалось, что кто-то может работать посменно, кто-то сутками, а еще существовал дивный параметр, позволявший ограничить время, которое считалось рабочим днем. То есть, если ты ушел с работы на 5 минут раньше – это будет отмечено, а вот если пришел на работу раньше – ничего подобного, счет начнется с утвержденного времени начала рабочего дня.
На тестовый прогон подсунули программе некую базу реальной конторы. И все вроде бы считалось хорошо, но внимательные тестеры обнаружили некоего гражданина, у которого суммарное рабочее время было отрицательным. Мы, конечно, стали искать ошибку в подсчете. Ошибок в нем не было, все стройно и логично, время ухода минус время прихода, или начала рабочего дня, если пришел раньше чем надо. А сумма отрицательная, хоть ты тресни!
Оказалось, что этот зловредный дядя приходил за два часа до начала рабочего дня, а уходил... за час до его начала. А мне, как нормальному разработчику, который прекрасно понимает людей, способных смыться из конторы за час до конца дня или наоборот проторчать до полуночи, даже в голову не приходило, что найдется деятель, способный уйти раньше, чем остальные на работу приходят. Программа честно вычитала из времени ухода время начала дня, получала примерно минус час и впихивала это в результат.
Я крякнул и спросил, как мне реагировать на такое самоуправство. Начальство почесало репу и выдало: ну раз уж он такой умный, что явился невовремя, хотя ограничение на день стоит – значит вообще эту явку не учитывай. Так я и сделал, но с тех пор при разработке программ стараюсь учесть не только все возможные комбинации ситуаций, но и все невозможные и ряд невероятных.
#369: Ничего не изменилось
16 декабря 2008, 20:30. рейтинг: 2642
У нас политика – мы не знаем пароли юзеров. Звонит как-то девушка:
Девушка: У меня почта не приходит в thunderbird..
Я: Сейчас сменю тебе пароль и зайду на webmail посмотрю, что тебе там пришло.
Меняю пароль на 123, захожу на вебмыло, вижу что почты новой нет, отправляю от себя письмо юзеру, на webmail приходит без проблем.
Я: Принимай у себя почту в thunderbird (забываю сказать, что нужно указать новый пароль).
Девушка: О, от тебя пришло письмо.
Я: Как это, пришло письмо?
Девушка: Ну, ты же мне отправил письмо, вот оно пришло, тема – "тест 1".
Я: Я тебе сменил пароль, ты не могла получить почту, не указав новый пароль: 123.
Девушка: Так у меня и был 123...
17 декабря 2008, 09:00. рейтинг: 2711
Утро, ресторан быстрого обслуживания, наш главный клиент. Я приехал обновлять ПО на кассах до новой версии.
Апдейт и патч прошли на ура, вроде все нормально и тут – горе мне луковое – не открываются денежные ящики, только ключом. Я в тихом ужасе – к десяти утра у кассиров очереди по десять человек, а тут такой сюрприз. Отзвонился разработчику, оказалось – не предусмотрели хитровыщипанность сочетания торгового оборудования от разных производителей. Сижу, жду новостей из тыла, деликатно выясняю у главного менеджера ресторана и регионального менеджера – что им больше нравится, когда открывается ящик или когда работает дисплей покупателя.
В менеджерскую зачем-то заглядывает девушка-кассир и, попутно, сообщает, что она встала на кассу, а там не открывается денежный ящик.
– Да, мы уже в курсе – отвечаю я – все денежные ящики пока не работают, открываются только ключом!
– Да? Хм, странно, на моей старой кассе все работало!
Я в замешательстве выхожу в зал и обнаруживаю, что на одной из касс ящик действительно работает адекватно. Пару секунд ступора и до меня доходит – систему не включили во время обновления, клиентские бинарники не обновились.
Закрываю систему и захожу в неё заново – билд сменился, ящик не открывается.. Я успокоился и, с чувством выполненного долга, сообщаю кассиру:
– Все в порядке, я починил вашу кассу – (давно не видел такой кратковременной улыбки!) – теперь на ней ящик также не работает, как и на остальных!
17 декабря 2008, 09:00. рейтинг: 2380
Процесс переезда в новый административный корпус очень затянулся.
Строительство и все дела. Мы, что характерно, тянули там сетку. Вернее, тянули монтеры, а меня, как самого сильного админа, прикрепил к ним для ускорения процесса. Все в лучших народных традициях – сроки горят, зад в мыле, и тут нас просят докинуть еще десяток внеплановых кабелей на первом этаже. Нужно пробивать еще одно отверстие в несущей стене или рассверливать старое.
Сверлить нужно под подвесным потолком, да еще пробить дырку так, чтобы не врезаться в гипсокартонный потолок на лестничной площадке. Я примеряюсь по уже имеющемуся отверстию электриков и пробиваю отверстие. Затем обращаю внимание ,что пробил какой-то странный кабель. Приглядевшись, понимаю, что это наше оптоволокно.
Оказывается, сеть здесь тянулась в два этапа. В первый этап, еще до меня, здесь сделали кабелеводы в стенах и кинули оптоволокно. Добрые строители оптоволокно заштукатурили, а часть кабелеводов задули монтажной пеной.
Внезапно я понимаю, что попал на бабки. Большие бабки. Присматриваюсь к кабелеводу электриков. Выдыхаю, понимаю, что на бабки попали все таки они – кабель пробит изначально ними.
Но потом оказалось, что и электриков пронесло.
При извлечении перебитого оптоволокна из-под штукатурки, выяснилось, что кабель в нескольких местах был тупо пробит гвоздями. Видать, оборвали кабель в процессе ремонта и решили прикрепить его на место.
Проматюкавшись, на следующий день скооперировались со связистами и начали перетягивать оптику. Строители отличились и тут. Входной кабелевод в здание оказался залит раствором. Причем свежим – заливали явно утром, причем зная, что мы будем тянуть линию в здание.
Виновных так и не нашли.
А вы говорите – бухгалтерия, электрики...
17 декабря 2008, 11:00. рейтинг: 1215
Когда я служил в части, у нас на объекте стоял компьютер. И было на нем много секретной информации. Возиться с засекречиванием/опечатыванием компьютера никому заниматься не хотелось, информация была нужна по ходу работы, а во время проверок его просто прятали. А проверки компьютеров военных на предмет содержания гос тайны – вещь довольно таки серьёзная.
И вот как-то приехала очередная проверка, начальника нету, я один. Заходит проверяющий – видит комп, находит на нем массу секретных документов. Отключает системник и отдает его прибывшим с ним солдатам отнести его в штаб части. А сам уходит дальше по объектам. Как только он ушел, я звоню начальнику – он приезжает по-быстрому, находит солдат, подключает системник к монитору в финчасти и быстренько удаляет все материалы. А на все вопросы проверяющего потом приходилось разводить руками и намекать про какой-то таинственный вирус..