169 похожих чатов

Всем привет, есть вопрос как правильно проверять файл на максимальный

размер, на расширение, прописывать эту логику в сервисе или с помощью анотации и писать кастомный валидатор в спринге, как чаще всего делают в реальных проектах?
Ещё вопрос есть сколько времени обычно уходит на покрытие кода тестами, например чтобы покрыть тестами 5 классов с 5 методами?

16 ответов

4 просмотра

От 1 минуты да месяца

У нас в проекте есть white/black list, проверяем наличие расширения после имени файла. По тестам — бессмысленный вопрос. Что тебе эта метрика даст?

Георгий- Автор вопроса
Дмитрий
У нас в проекте есть white/black list, проверяем н...

А где проверяете расширение прямо в сервисе? По тестами да понимаю, просто когда пишу тесты уходит почему-то очень много времени, поэтому интересно

Георгий
А где проверяете расширение прямо в сервисе? По те...

Очень много времени - это сколько? Тоже ни о чем. ты же только учишься. С опытом времени будет уходить меньше.

Георгий
А где проверяете расширение прямо в сервисе? По те...

Можно сказать, в сервисе. Перед тем как что-то делать с файлом, сначала его проверяем.

Георгий- Автор вопроса

Ну вот на это я потратил минут 15, можете оценить правильность тесты и что бы вы тут изменили? Тут логика добавления объявления с изображением

Георгий
screenshot Ну вот на это я потратил минут 15, можете оценить ...

Я бы не писал файлы в базу. ассерт каждого поля делать не вижу смысла. Либо используй ReflectionEquals, либо делай ассерт того что записалось в базу с тем, что пришло из реквеста. Трай кетч я бы унес куда то вглубь, ближе к потенциальному источнику исключения. По моканию сервисов — можно сделать мок в @BeforeAll один раз, так как тебе с этими моками скорее всего нужно тестить и другие методы

Георгий- Автор вопроса
Дмитрий
Я бы не писал файлы в базу. ассерт каждого поля де...

У меня файл репозиторий пишет в minio, я не очень понял про проверку того что записалось в базу, сейчас как раз проверяю что записалось, ReflectionEquals не могу использовать, у меня там поля по разному у объектов называются, я же правильно понимаю что он по полям одинаковым просто сравнивает? вот трай кетч я тоже не могу убрать, потому что я тут получаю inputstream и отсюда ошибка, мне стоит тогда в filerepository не inputStream а MultipartFile сразу передавать?

Георгий- Автор вопроса
Дмитрий
Я бы не писал файлы в базу. ассерт каждого поля де...

про моки, это ты про то где у меня большой блок с when?

Георгий
У меня файл репозиторий пишет в minio, я не очень ...

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

Георгий- Автор вопроса
Дмитрий
ты ж маппером создаешь тип, который пишется в базу...

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

Георгий
У меня файл репозиторий пишет в minio, я не очень ...

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

Я не понял этого сообщения

Георгий- Автор вопроса
Дмитрий
Я не понял этого сообщения

Ну я про то что если в базе сохраняется то что я передаю в дто, то на выходе не нужно проверять что выходные параметры равны входным?

Георгий
Ну я про то что если в базе сохраняется то что я п...

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

Георгий- Автор вопроса

Похожие вопросы

Обсуждают сегодня

Сообщение* в закодированном виде. То есть, просто сделать sendMessage?text=Привет бла-бла! не получится, надо в HEX переводить, и добавлять процент, типа такого: sendMessage?t...
КТ315
21
А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Всем привет. Испытываю проблемы в работе БД, а именно огромного роста логов, такого характера: 024-05-16 18:39:07 +05 sentry sentry [unknown] 1050169 7-1 app-sentry01.corp.ru>...
Alexey
2
Если подытожить: По мнению Розыча и Хемуля и др. - предпочтительно по возможности объявлять в секции имплементации потому-что: 1) Выше скорость компиляции 2) Не замусоривается...
notme
7
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Хм. А телеграм апи работают через HTTP?
The Bird of Hermes
14
Почему Telegram пишет, что объект media не найден, хотя на самом деле я его передаю? Делаю на urllib, без зависимостей, так надо. Вызываю метод sendMediaGroup с таким JSON: ...
Alexey S
1
В дельфе нет никакого коробочного (без установки третьих либ) способа получить CallStack с расшифровкой отладочных символов?
notme
7
Приветики всем!)) Подскажите: есть функция, которая записывает число типа Cardinal в четыре байта, хранимые в TBytes. Можете помочь мне, показав, как должна выглядеть функци...
Моринаро
5
Карта сайта