51 lines
1.7 KiB
Ruby
51 lines
1.7 KiB
Ruby
|
require 'spec_helper'
|
||
|
require_dependency 'auth/default_current_user_provider'
|
||
|
|
||
|
describe Auth::DefaultCurrentUserProvider do
|
||
|
|
||
|
def provider(url, opts=nil)
|
||
|
opts ||= {method: "GET"}
|
||
|
env = Rack::MockRequest.env_for(url, opts)
|
||
|
Auth::DefaultCurrentUserProvider.new(env)
|
||
|
end
|
||
|
|
||
|
it "raises errors for incorrect api_key" do
|
||
|
expect{
|
||
|
provider("/?api_key=INCORRECT").current_user
|
||
|
}.to raise_error(Discourse::InvalidAccess)
|
||
|
end
|
||
|
|
||
|
it "finds a user for a correct per-user api key" do
|
||
|
user = Fabricate(:user)
|
||
|
ApiKey.create!(key: "hello", user_id: user.id, created_by_id: -1)
|
||
|
provider("/?api_key=hello").current_user.id.should == user.id
|
||
|
end
|
||
|
|
||
|
it "raises for a user pretending" do
|
||
|
user = Fabricate(:user)
|
||
|
user2 = Fabricate(:user)
|
||
|
ApiKey.create!(key: "hello", user_id: user.id, created_by_id: -1)
|
||
|
|
||
|
expect{
|
||
|
provider("/?api_key=hello&api_username=#{user2.username.downcase}").current_user
|
||
|
}.to raise_error(Discourse::InvalidAccess)
|
||
|
end
|
||
|
|
||
|
it "finds a user for a correct system api key" do
|
||
|
user = Fabricate(:user)
|
||
|
ApiKey.create!(key: "hello", created_by_id: -1)
|
||
|
provider("/?api_key=hello&api_username=#{user.username.downcase}").current_user.id.should == user.id
|
||
|
end
|
||
|
|
||
|
it "should not update last seen for message bus" do
|
||
|
provider("/message-bus/anything/goes", method: "POST").should_update_last_seen?.should == false
|
||
|
provider("/message-bus/anything/goes", method: "GET").should_update_last_seen?.should == false
|
||
|
end
|
||
|
|
||
|
it "should update last seen for others" do
|
||
|
provider("/topic/anything/goes", method: "POST").should_update_last_seen?.should == true
|
||
|
provider("/topic/anything/goes", method: "GET").should_update_last_seen?.should == true
|
||
|
end
|
||
|
end
|
||
|
|