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

Привет. Есть некоторый класс, который внутри себя хранит логгер, вот

так:

class MyClass
{
//...
public function __construct(string $uuid)
{
//...
$this->logger = Log::build([
'driver' => 'daily',
'days' => 1,
'path' => storage_path('logs/something/history.log'),
]);
//...
}
//...
}

Теперь я пишу тест для MyClass и хочу понять логирует ли он что надо куда надо.

Мок Log::shouldReceive('info')... шлёт хером, потому что перед моими $myclass->logger->info() стреляет какой-то error().

Storage::fake() вроде должен помочь (возвращает storage/framework/testing/disks/testing), но storage_path() в конструкторе MyClass возвращает storage/logs/something/history.log. Плюс странность в том, что в итоге ничего не пишется ни туда, ни сюда.

Есть кто побеждал такие вещи?

2 ответов

5 просмотров

Твой класс создаётся через провайдер?

Anthony-Axenov Автор вопроса
Sergey Chizhik
Твой класс создаётся через провайдер?

вообще да, биндится синглтоном в \App\Providers\AppServiceProvider::boot() $this->app->singleton('my', MyClass::class); на setUp теста прокидывается в контейнер так: app()->when(MyClass::class)->needs('$uuid')->give('faba77df-c86f-46aa-a074-9079b58169bb')

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

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

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Заметил в ghci 9.4.8: > :t (<*>) @((->)_) (<*>) @((->)_) :: (w -> (a -> b)) -> (w -> a) -> w -> b Разве не должно (w -> (a -> b)) быть записано как (w -> a -> b)? Это баг, ил...
Михаил
13
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Any electron dev here?
Sayanth Tezro
12
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
так это может кто что знает или использует что-то как макбук только не макбук? на 13…14 дюймов
Michael
9
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Кто-нибудь знает почему SPM клонирует репо целиком? Некоторые репы просто огромные, как та же swift-syntax которая нужна для использования макросов. Сначала подумал, что это...
iMike
6
Карта сайта