2013-10-21 13:49:51 -05:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe Admin::ScreenedIpAddressesController do
|
2014-11-24 10:25:48 -06:00
|
|
|
|
2013-10-21 13:49:51 -05:00
|
|
|
it "is a subclass of AdminController" do
|
2014-09-25 10:44:48 -05:00
|
|
|
(Admin::ScreenedIpAddressesController < Admin::AdminController).should == true
|
2013-10-21 13:49:51 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
let!(:user) { log_in(:admin) }
|
|
|
|
|
2013-10-22 15:30:30 -05:00
|
|
|
describe 'index' do
|
2014-11-24 10:25:48 -06:00
|
|
|
|
|
|
|
it 'returns JSON' do
|
2013-10-21 13:49:51 -05:00
|
|
|
xhr :get, :index
|
2014-11-24 10:25:48 -06:00
|
|
|
response.should be_success
|
|
|
|
JSON.parse(response.body).should be_a(Array)
|
2013-10-21 13:49:51 -05:00
|
|
|
end
|
|
|
|
|
2014-11-24 10:25:48 -06:00
|
|
|
end
|
2013-10-21 13:49:51 -05:00
|
|
|
|
2014-11-24 10:25:48 -06:00
|
|
|
describe 'roll_up' do
|
|
|
|
|
2014-11-27 12:29:30 -06:00
|
|
|
it "rolls up 1.2.3.* entries" do
|
2014-11-24 10:25:48 -06:00
|
|
|
Fabricate(:screened_ip_address, ip_address: "1.2.3.4", match_count: 1)
|
|
|
|
Fabricate(:screened_ip_address, ip_address: "1.2.3.5", match_count: 1)
|
|
|
|
Fabricate(:screened_ip_address, ip_address: "1.2.3.6", match_count: 1)
|
|
|
|
|
|
|
|
Fabricate(:screened_ip_address, ip_address: "42.42.42.4", match_count: 1)
|
|
|
|
Fabricate(:screened_ip_address, ip_address: "42.42.42.5", match_count: 1)
|
|
|
|
|
2014-11-24 12:48:54 -06:00
|
|
|
StaffActionLogger.any_instance.expects(:log_roll_up)
|
2014-11-27 12:29:30 -06:00
|
|
|
SiteSetting.stubs(:min_ban_entries_for_roll_up).returns(3)
|
2014-11-24 12:48:54 -06:00
|
|
|
|
2014-11-24 10:25:48 -06:00
|
|
|
xhr :post, :roll_up
|
|
|
|
response.should be_success
|
|
|
|
|
|
|
|
subnet = ScreenedIpAddress.where(ip_address: "1.2.3.0/24").first
|
|
|
|
subnet.should be_present
|
|
|
|
subnet.match_count.should == 3
|
2013-10-21 13:49:51 -05:00
|
|
|
end
|
2014-11-24 10:25:48 -06:00
|
|
|
|
2014-11-27 12:29:30 -06:00
|
|
|
it "rolls up 1.2.*.* entries" do
|
|
|
|
Fabricate(:screened_ip_address, ip_address: "1.2.3.4", match_count: 1)
|
|
|
|
Fabricate(:screened_ip_address, ip_address: "1.2.3.5", match_count: 1)
|
|
|
|
Fabricate(:screened_ip_address, ip_address: "1.2.4.6", match_count: 1)
|
|
|
|
Fabricate(:screened_ip_address, ip_address: "1.2.7.8", match_count: 1)
|
|
|
|
Fabricate(:screened_ip_address, ip_address: "1.2.9.1", match_count: 1)
|
|
|
|
|
|
|
|
Fabricate(:screened_ip_address, ip_address: "1.2.42.0/24", match_count: 1)
|
|
|
|
|
|
|
|
StaffActionLogger.any_instance.expects(:log_roll_up)
|
|
|
|
SiteSetting.stubs(:min_ban_entries_for_roll_up).returns(5)
|
|
|
|
|
|
|
|
xhr :post, :roll_up
|
|
|
|
response.should be_success
|
|
|
|
|
|
|
|
subnet = ScreenedIpAddress.where(ip_address: "1.2.0.0/16").first
|
|
|
|
subnet.should be_present
|
|
|
|
subnet.match_count.should == 6
|
|
|
|
end
|
|
|
|
|
2013-10-21 13:49:51 -05:00
|
|
|
end
|
2014-11-24 10:25:48 -06:00
|
|
|
|
2013-10-21 13:49:51 -05:00
|
|
|
end
|