rspecでログのテスト備忘録 Railsの特定のログがinfoで一回だけ呼ばれることをテストしたい 処理の途中経過やベンチマーク結果等が出ていることを確認したい rspecでRails.logger.should_receive(:info).with(expected).onceのように書きたい これだと、infoで呼ばれたすべてのログに対してチェックしてしまう 解決法 Rails.logger.stub(:info => nil)を使う withで渡したログ形式とマッチした回数をテストできる before do Rails.logger.stub(:info => nil) expected = { :type => "benchmark", :category => "upload", :realtime => anything } Rails.logger.should_rece
![rspecで特定のログが吐かれていることを確認する - Qiita](https://cdn-ak-scissors.b.st-hatena.com/image/square/c644a72ab107d1089067d57ce8421a093981acdc/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9cnNwZWMlRTMlODElQTclRTclODklQjklRTUlQUUlOUElRTMlODElQUUlRTMlODMlQUQlRTMlODIlQjAlRTMlODElOEMlRTUlOTAlOTAlRTMlODElOEIlRTMlODIlOEMlRTMlODElQTYlRTMlODElODQlRTMlODIlOEIlRTMlODElOTMlRTMlODElQTglRTMlODIlOTIlRTclQTIlQkElRTglQUElOEQlRTMlODElOTklRTMlODIlOEImdHh0LWNvbG9yPSUyMzIxMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT01NiZ0eHQtY2xpcD1lbGxpcHNpcyZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPTkxNTczMzk1ZjFkZGY3NzcyZmZmZTU5OTY2ZDc4Zjg4%26mark-x%3D142%26mark-y%3D112%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwb2dhd2F0dGkmdHh0LWNvbG9yPSUyMzIxMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT0zNiZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPWQwN2U1ZTJjMGYzNGJhOTg5NGVlYjliOWQxZjQ2Zjli%26blend-x%3D142%26blend-y%3D491%26blend-mode%3Dnormal%26s%3Da0398f661dc997759ed60fd05453380b)