forked from collectiveidea/audited
/
audit_sweeper_spec.rb
74 lines (52 loc) · 1.5 KB
/
audit_sweeper_spec.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
require 'spec_helper'
class AuditsController < ActionController::Base
def audit
@company = Company.create
render :nothing => true
end
def update_user
current_user.update_attributes( :password => 'foo')
render :nothing => true
end
private
attr_accessor :current_user
attr_accessor :custom_user
end
describe AuditsController do
include RSpec::Rails::ControllerExampleGroup
before(:each) do
ActsAsAudited.current_user_method = :current_user
end
let( :user ) { create_user }
describe "POST audit" do
it "should audit user" do
controller.send(:current_user=, user)
expect {
post :audit
}.to change( Audit, :count )
assigns(:company).audits.last.user.should == user
end
it "should support custom users for sweepers" do
controller.send(:custom_user=, user)
ActsAsAudited.current_user_method = :custom_user
expect {
post :audit
}.to change( Audit, :count )
assigns(:company).audits.last.user.should == user
end
it "should record the remote address responsible for the change" do
request.env['REMOTE_ADDR'] = "1.2.3.4"
controller.send(:current_user=, user)
post :audit
assigns(:company).audits.last.remote_address.should == '1.2.3.4'
end
end
describe "POST update_user" do
it "should not save blank audits" do
controller.send(:current_user=, user)
expect {
post :update_user
}.to_not change( Audit, :count )
end
end
end