2023-10-11 06:10PM
puts 是在命令行里面打印输出。使用 puts
进行临时输出、调试和验证代码逻辑。
Rails.logger 是在日志里面打印输出。使用 Rails.logger
记录应用程序的运行时信息、错误和重要事件。
eg :
puts
test "should get index width paramater" do
# 打印出所有的 Manager 记录
puts Manager.all.inspect
assert_equal 3, Manager.count
assert Manager.count == 3
get managers_url, params: { email: "admin@email.com" }
assert_equal 1, assigns(:managers).size
assert_response :success
end
运行命令行输出:
$ bundle exec rails test test/controllers/managers_controller_test.rb:18
Run options: --seed 24542
# Running:
#<ActiveRecord::Relation [#<Manager id: 529899929, email: "admin2@email.com", created_at: "2023-10-11 10:03:48.784041000 +0000", updated_at: "2023-10-11 10:03:48.784041000 +0000", category: "管理员", region_id: nil, name: nil, owner: nil, status: nil>, #<Manager id: 680694018, email: "baogong_user_1@email.com", created_at: "2023-10-11 10:03:48.784041000 +0000", updated_at: "2023-10-11 10:03:48.784041000 +0000", category: nil, region_id: nil, name: nil, owner: nil, status: nil>, #<Manager id: 832291002, email: "admin@email.com", created_at: "2023-10-11 10:03:48.784041000 +0000", updated_at: "2023-10-11 10:03:48.784041000 +0000", category: nil, region_id: nil, name: nil, owner: nil, status: nil>]>
.
Finished in 0.305378s, 3.2746 runs/s, 13.0985 assertions/s.
1 runs, 4 assertions, 0 failures, 0 errors, 0 skips
Rails.logger
test "should get index width paramater" do
# 将Manager
模型的所有记录以 字符串的形式打印到 Rails 日志中
Rails.logger.info "====Manager: #{Manager.all}"
assert_equal 3, Manager.count
assert Manager.count == 3
get managers_url, params: { email: "admin@email.com" }
assert_equal 1, assigns(:managers).size
assert_response :success
end
运行日志输出:
TRANSACTION (0.2ms) BEGIN
-------------------------------------------------------------
ManagersControllerTest: test_should_get_index_width_paramater
-------------------------------------------------------------
Manager Load (0.6ms) SELECT `managers`.* FROM `managers` WHERE `managers`.`id` = 529899929 LIMIT 1
Manager Load (0.4ms) SELECT `managers`.* FROM `managers` WHERE `managers`.`id` = 832291002 LIMIT 1
====Manager: #<Manager::ActiveRecord_Relation:0x000055a7c347e508>
Manager Count (0.5ms) SELECT COUNT(*) FROM `managers`
CACHE Manager Count (0.0ms) SELECT COUNT(*) FROM `managers`
Started GET "/managers?email=admin%40email.com" for 127.0.0.1 at 2023-10-11 18:05:39 +0800
TRANSACTION (0.3ms) SAVEPOINT active_record_1
Manager Update (0.5ms) UPDATE `managers` SET `managers`.`updated_at` = '2023-10-11 10:05:39.751227', `managers`.`current_sign_in_at` = '2023-10-11 10:05:39.750463', `managers`.`last_sign_in_at` = '2023-10-11 10:05:39.750463', `managers`.`current_sign_in_ip` = '127.0.0.1', `managers`.`last_sign_in_ip` = '127.0.0.1', `managers`.`sign_in_count` = 1 WHERE `managers`.`id` = 529899929
TRANSACTION (0.2ms) RELEASE SAVEPOINT active_record_1
Processing by ManagersController#index as HTML
Parameters: {"email"=>"admin@email.com"}
Rendering layout layouts/application.html.erb
Rendering managers/index.html.erb within layouts/application
Manager Load (0.5ms) SELECT `managers`.* FROM `managers` WHERE (email LIKE '%admin@email.com%') ORDER BY `managers`.`created_at` DESC LIMIT 10 OFFSET 0
Rendered managers/index.html.erb within layouts/application (Duration: 4.8ms | Allocations: 3530)
Message Count (0.3ms) SELECT COUNT(*) FROM `messages` WHERE `messages`.`recipient_id` = 529899929 AND `messages`.`read` = FALSE
Rendered home/_charts_menu.html.erb (Duration: 1.0ms | Allocations: 883)
Rendered home/_statistics_menu.html.erb (Duration: 0.7ms | Allocations: 583)
Rendered home/_warn_menu.html.erb (Duration: 0.7ms | Allocations: 582)
Rendered home/_enterprises_menu.html.erb (Duration: 0.9ms | Allocations: 731)
Rendered home/_managers_menu.html.erb (Duration: 0.5ms | Allocations: 320)
Rendered home/_menu.html.erb (Duration: 7.6ms | Allocations: 5688)
Rendered layout layouts/application.html.erb (Duration: 26.6ms | Allocations: 20490)
Completed 200 OK in 35ms (Views: 27.5ms | ActiveRecord: 2.1ms | Allocations: 26869)
TRANSACTION (2.4ms) ROLLBACK
登录
请登录后再发表评论。
评论列表:
目前还没有人发表评论