/*
* Copyright (c) 2010 Lockheed Martin Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.eurekastreams.server.action.execution.opensocial;
import org.apache.shindig.auth.SecurityToken;
import org.apache.shindig.gadgets.oauth.OAuthStore.ConsumerInfo;
import org.eurekastreams.commons.actions.context.PrincipalActionContext;
import org.eurekastreams.commons.exceptions.ExecutionException;
import org.eurekastreams.server.action.request.opensocial.GetConsumerTokenInfoRequest;
import org.eurekastreams.server.action.response.opensocial.TokenInfoResponse;
import org.eurekastreams.server.domain.OAuthConsumer;
import org.eurekastreams.server.domain.OAuthToken;
import org.eurekastreams.server.persistence.mappers.DomainMapper;
import org.eurekastreams.server.persistence.mappers.requests.opensocial.OAuthConsumerRequest;
import org.eurekastreams.server.persistence.mappers.requests.opensocial.OAuthTokenRequest;
import org.jmock.Expectations;
import org.jmock.Mockery;
import org.jmock.integration.junit4.JUnit4Mockery;
import org.jmock.lib.legacy.ClassImposteriser;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
/**
* Test suite for {@link GetConsumerTokenInfoExecution}.
*/
@SuppressWarnings("unchecked")
public class GetConsumerTokenInfoExecutionTest
{
/**
* System under test.
*/
private GetConsumerTokenInfoExecution sut;
/**
* Context for building mock objects.
*/
private final Mockery context = new JUnit4Mockery()
{
{
setImposteriser(ClassImposteriser.INSTANCE);
}
};
/**
* Instance of OAuth consumer mapper injected by spring.
*/
private final DomainMapper<OAuthConsumerRequest, OAuthConsumer> consumerMapper = context.mock(DomainMapper.class,
"consumerMapper");
/**
* Instance of OAuth token mapper injected by spring.
*/
private final DomainMapper<OAuthTokenRequest, OAuthToken> tokenMapper = context.mock(DomainMapper.class,
"tokenMapper");
/**
* Mocked instance of the action context.
*/
private PrincipalActionContext actionContext = context.mock(PrincipalActionContext.class);
/**
* Mocked instance of the security token.
*/
private SecurityToken securityToken = context.mock(SecurityToken.class);
/**
* Mocked instance of the consumer info.
*/
private ConsumerInfo consumerInfo = context.mock(ConsumerInfo.class);
/**
* Prepare the sut.
*/
@Before
public void setup()
{
sut = new GetConsumerTokenInfoExecution(consumerMapper, tokenMapper);
}
/**
* Test getTokenInfo that returns a null token.
*
* @throws Exception
* - covers all exceptions.
*/
@Test
public void testGetNullTokenInfo() throws Exception
{
context.checking(new Expectations()
{
{
oneOf(actionContext).getParams();
will(returnValue(new GetConsumerTokenInfoRequest(securityToken, consumerInfo, "serviceName",
"tokenName")));
oneOf(securityToken).getAppUrl();
will(returnValue("http://localhost:4040/some/path"));
oneOf(securityToken).getViewerId();
will(returnValue("123"));
oneOf(securityToken).getOwnerId();
will(returnValue("456"));
oneOf(consumerMapper).execute(with(any(OAuthConsumerRequest.class)));
will(returnValue(new OAuthConsumer("", "", "", "", "")));
oneOf(tokenMapper).execute(with(any(OAuthTokenRequest.class)));
will(returnValue(null));
}
});
TokenInfoResponse response = (TokenInfoResponse) sut.execute(actionContext);
Assert.assertTrue("Token response was found", response == null);
context.assertIsSatisfied();
}
/**
* Test normal path through getTokenInfo.
*
* @throws Exception
* - covers all exceptions.
*/
@Test
public void testGetTokenInfo() throws Exception
{
context.checking(new Expectations()
{
{
oneOf(actionContext).getParams();
will(returnValue(new GetConsumerTokenInfoRequest(securityToken, consumerInfo, "serviceName",
"tokenName")));
OAuthConsumer consumer = new OAuthConsumer("", "", "", "", "");
OAuthToken token = new OAuthToken(consumer, "", "", "", "");
token.setTokenExpireMillis(0L);
oneOf(securityToken).getAppUrl();
will(returnValue("http://localhost:4040/some/path"));
oneOf(securityToken).getViewerId();
will(returnValue("123"));
oneOf(securityToken).getOwnerId();
will(returnValue("456"));
oneOf(consumerMapper).execute(with(any(OAuthConsumerRequest.class)));
will(returnValue(new OAuthConsumer("", "", "", "", "")));
oneOf(tokenMapper).execute(with(any(OAuthTokenRequest.class)));
will(returnValue(token));
}
});
TokenInfoResponse response = (TokenInfoResponse) sut.execute(actionContext);
Assert.assertNotNull("Token was not found", response.getTokenInfo());
context.assertIsSatisfied();
}
/**
* Test null consumer key with getTokenInfo.
*
* @throws Exception
* - covers all exceptions.
*/
@Test(expected = ExecutionException.class)
public void testGetTokenWithNullConsumerKey() throws Exception
{
context.checking(new Expectations()
{
{
oneOf(actionContext).getParams();
will(returnValue(new GetConsumerTokenInfoRequest(securityToken, consumerInfo, "serviceName",
"tokenName")));
oneOf(securityToken).getAppUrl();
will(returnValue("http://localhost:4040/some/path"));
oneOf(consumerMapper).execute(with(any(OAuthConsumerRequest.class)));
will(returnValue(null));
}
});
sut.execute(actionContext);
context.assertIsSatisfied();
}
}