Opened 13 months ago

Last modified 10 months ago

#1239 reopened улучшение

Хаос в истории изделия в интерфейсе "Тестирование" — at Version 22

Reported by: alx Owned by: Denis_N
Priority: major Component: БД изделий АДС
Keywords: Cc:

Description (last modified by alx)

В r325/base в интерфейсе "Тестирование" после пары неудачных тестирований и устранений неисправностей в истории изделия отображается какой-то хаос:


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

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

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

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

По второй проблеме предлагаю изменить отображение истории изделия в интерфейсе "Тестирование" таким образом, чтобы пользователи могли понять, какие записи относятся к одному и тому же несоответствию, а какие - к разным. Как один из возможных вариантов решения могу предложить группировать записи, относящиеся к одному и тому же несоответствию, в одну общую запись:


Несоответствие:
Обнаружено: Иван Напримеров, 12 января 2022 в 15:54:23: Нет линка у интерфейсе eth5.
Ремонт: Петр Степанов, 15 января 2022 в 11:24:54 - Неуспешно: Грелась D4. Заменил, но не помогло.
Ремонт: Петр Степанов, 15 января 2022 в 12:11:27 - Успешно: Заменил еще и D7.


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

Change History (23)

by alx, 13 months ago

Attachment: ss1.jpg added

comment:1 by alx, 13 months ago

Description: modified (diff)

comment:2 by alx, 13 months ago

Дополню немного. Довольно типичная ситуация в жизненном цикле изделия:

  • обнаруживается неисправность (типично - при первоначальном тестировании изделия): изделие неправильно себя ведет - в БД делается запись о несоответствии.
  • производится поиск причины неисправности, обнаруживается дефект (например дефект монтажа - замыкание между контактами компонента) - и вот тут проблема: у обнаружившего дефект нет возможности его адекватно занести в БД. Если он делает запись о несоответствии - получается, что у изделия есть уже два несоответствия, что не соответствует действительности, так как одно (первое) несоответствие является проявлением второго (дефекта монтажа). Если же занести это просто как комментарий, то он не будет "привязан" ни к какому несоответствию, что тоже неправильно.
  • наконец, когда дефект устранен, в БД заносится запись об устранении несоответствия.

Я считаю, что в веб-интерфейсе должна быть возможность "открыть конкретное несоответствие" (подобно тому как есть возможность "открыть историю конкретного изделия"): при клике чего-то (например записи о несоответствии) должна открываться страница с отображением всех записей (и только их), связанных с данным конкретным несоответствием. На этой странице должна быть возможность не только добавить запись об устранении несоответствия, но и добавлять любые комментарии к данному конкретному несоответствию.

in reply to:  description ; comment:3 by Denis_N, 11 months ago

Мне нравится твое предложение полностью, Алексей.

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

Хотел только спросить, как ты видишь реализацию этого поля флагов в бд?

Replying to alx:

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

in reply to:  3 ; comment:4 by alx, 11 months ago

Replying to Denis_N:

Хотел только спросить, как ты видишь реализацию этого поля флагов в бд?

Я вижу примерно так. Поле type_write имеет тип BIT вместо ENUM. Существующим типам записей (record, testimg, mismatch и т.п.) ставятся в соотетствие биты этого поля (b'0001', b'0010', b'0100' и т.д.). В результате появляется возможность комбинировать типы в одной записи:

b'0010' - testing,
b'0100' - mismatch,
b'0110' - testing и mismatch одновременно.

Проверки значения поля type_write на равенство конкретному значению меняются на проверки установки какого-либо бита: WHERE type_write & 1...

comment:5 by Denis_N, 11 months ago

Спасибо. Почитаю про тип BIT

in reply to:  4 ; comment:6 by san, 11 months ago

Replying to alx:

Я вижу примерно так. Поле type_write имеет тип BIT вместо ENUM.

Мне кажется битовый тип не очень нагляден(человекочитаем) и выборку из базы по битовому полю делать сложнее.
На мой взгляд вместо битового типа было бы удобнее использовать отдельные поля ENUM для каждого действия, которые будут содержать признак типа записи (NULL или нет) и сразу конкретное значение, т.е. предлагаю вообще убрать тип записи. Выглядеть запись в истории будет как-то так:

record==NULLtesting==NULLmistmatch==yesotk==fail

что будет соответствовать типу записи b'0101' в твоём примере и означать - плата не прошла ОТК т.к. обнаружено несоответствие

in reply to:  6 comment:7 by alx, 11 months ago

Replying to san:

На мой взгляд вместо битового типа было бы удобнее использовать отдельные поля ENUM для каждого действия, которые будут содержать признак типа записи (NULL или нет)

ENUM с единственным значением? Оригинально... :) Принципиальных возражений нет.

comment:8 by san, 11 months ago

ENUM с единственным значением? Оригинально... :) Принципиальных возражений нет.

Ну не обязательно единственным, хотя в вырожденном случаем может быть и так.
testing и отк могут принимать значения NULL, ok или fail.
mistmatch - может быть, например: [Null, "обнаружено", "комментарий", "устранено"].

in reply to:  8 comment:9 by alx, 11 months ago

Replying to san:

testing и отк могут принимать значения NULL, ok или fail.

Могут, конечно, но это будет избыточно, так как успешность тестирования и контроля ОТК уже есть в поле status.

mistmatch - может быть, например: [Null, "обнаружено", "комментарий", "устранено"].

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

comment:10 by san, 11 months ago

много всяких значений вместо одного бита. Непонятно только, зачем... :)

По всяким не битовым значениям проще и наглядней делать запрос в базу, например условие where otk='fail' мне нравится больше чем что-то типа where type_write & b’0001′ AND status='fail' (с синтаксисом я наверняка наврал, но суть должна быть понятна)

Last edited 11 months ago by san (previous) (diff)

in reply to:  10 ; comment:11 by alx, 11 months ago

Replying to san:

По всяким не битовым значениям проще и наглядней делать запрос в базу, например условие where otk='fail' мне нравится больше чем что-то типа where type_write & b’0001′ AND status='fail' (с синтаксисом я наверняка наврал, но суть должна быть понятна)

Во-первых, я в comment:7 написал, что принципиальных возражений против использования типа ENUM у меня нет.

Во-вторых, с утверждением о том, что при нескольких значениях EMUM вместо одного запрос получается нагляднее, я согласиться не могу. Ведь придется писать что-то типа WHERE mismatch = 'обнаружено' OR mismatch = 'устранено' вместо WHERE NOT ISNULL(mismatch) или WHERE mismatch = 'yes'.

Last edited 11 months ago by alx (previous) (diff)

in reply to:  11 comment:12 by alx, 11 months ago

Случайно ответил сам себе. :)

Last edited 11 months ago by alx (previous) (diff)

comment:13 by Denis_N, 11 months ago

Алексей, а что ты думаешь насчет типа SET? Подошел бы он для реализации данного тикета? В чем его плюсы и минусы в сравнении с BIT-овым вариантом реализации, на твой взгляд?

in reply to:  13 ; comment:14 by alx, 11 months ago

Replying to Denis_N:

Алексей, а что ты думаешь насчет типа SET?

Нормальный вроде бы тип... Ничего особенного не думаю. :)

Подошел бы он для реализации данного тикета?

Думаю, вполне бы подошел.

В чем его плюсы и минусы в сравнении с BIT-овым вариантом реализации, на твой взгляд?

Это фактически один и тот же тип - 64-битное число. Плюс в том, что кроме числового значения каждый бит представляется определенной строкой, что может сделать запросы более наглядными (понятными). Минусов, честно говоря, не вижу...

in reply to:  14 comment:15 by Denis_N, 11 months ago

Спасибо большое, Алексей

comment:16 by Denis_N, 10 months ago

In 334/base:

Улучшение: интерфейс подготовлен к тому, что теперь тип столбца type_write измениться на set; и к тому, что ячейка в столбце type_write может содержать сразу несколько значений типов записей

See #1239

comment:17 by Denis_N, 10 months ago

In 335/base:

Улучшение:
Убрал избыточность в условии, где указан тип записи

See #1239

comment:18 by Denis_N, 10 months ago

In 336/base:

Улучшение: теперь интерфейсы ОТК и Тестирование при неуспешном статусе записывают в базу одну строку с двумя типами записей
P.S. ранее заносились в базу две записи: первая - ОТК/Тестирование, вторая - Несоответствие

See #1239

comment:19 by san, 10 months ago

In 338/base:

Изменения в структуре БД
Изменен тип столбца history.type_write с ENUM на SET
See #1239

comment:20 by Denis_N, 10 months ago

Resolution: готово
Status: newclosed

in reply to:  20 comment:21 by alx, 10 months ago

Resolution: готово
Status: closedreopened

В r342/base сделал несколько записей о несоотетветствиях изделия, а также о неудачном тестировании. После этого сделал записи об устранении неисправностей. В результате я вижу, что при тестировании, действительно, в историю добавилась только одна запись. Однако никакой группировки отображаемых в истории записей я не обнаружил - как и раньше, отображается "хаос" из расположенных вразнобой записей об обнаружении и устранении несоответствий, и понять, какая именно запись об устранении несоответствия какие именно несоответствие устраненяет, по-прежнему нельзя (если об этом не написано в тексте комментария).

comment:22 by alx, 10 months ago

Description: modified (diff)

Исравил опечатки.

Note: See TracTickets for help on using tickets.