Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit fe62a9fd authored by Maria Asensio's avatar Maria Asensio
Browse files

Merge pull request #89 from owncloud/share_with_users__unit_tests

Unit tests updated to share with users
parents 875fce9f 5c488177
Loading
Loading
Loading
Loading
+4 −3
Original line number Original line Diff line number Diff line
sudo: false
language: android
language: android
android:
android:
  components:
  components:
@@ -20,8 +21,8 @@ script:
- ./gradlew clean build
- ./gradlew clean build
env:
env:
  global:
  global:
  - secure: HxHoqnC8mauCKi87zlo7pQcSsSw0W5MtW+iUcB8T11quwTBgUPWIOmycXv2FcmwpST0E43Ct+dhE+mttm+6P+5PSB33HQNLq00hfTVIJ4ttcb/5eWW8MnP7L+kPK8d0EtfDG6GQto7QktaybeG4+sNKKD336ZlFfM7xgPtPv+tg=
  - secure: a21NrzTCQnkTKtRGo7B1lyF2WWbpBT2N64V2Tf+oUcRLOUx3XM/mDi60mAdGd0WXV9tHD8GGmu0tQ7LGZ2VsIxixVxjzEYwX4HRTodewYez6WxBMjVEHHy+3jmc1zU4k3AAqr+uW7L4BKa5r9tH+nq9ecJMDMgW8o9MKXuP7Vso=
  - secure: WQMw0ciloe8i2ApGhePhuTmmH8UgAV1Ri10C1qhUH9hVOJAr+/1X5A93VPYGrgJ2EH5MdiL6f2XMDCYAgb9efuvZIUKNE0J92xh8m/yRa8nAVWNBE0PBdS4+OycoHpIQfMcUghooERXjP4GUYd/ZwICvWA+sXdOYWDdKjODUgl4=
  - secure: UVnaC5Qzat2C8WlMMb8aycz1ChZKjP8Kz89qBbVcqYK+PLAGKpUNxFa39/2oA5jkMyyOcXYC9bX1ZYzHLH7nJ8LbQgaxXMT4gvgvN0l6KezjDavIW60idD9BbugkwzNj/cjoU/DdxBykPsTn4vSRaESVNTdEbM27YU4FBPzTANY=
  - secure: QPxKT8vC7sm1b/hYJcfkQkLgpwNRBvVKk8S8S0t43mmqPJfs94FJTQHH4kZaGSwOeuDkRQbGuKzYtXOnGOKX2hhUBqKJd1idpJnUID8id8Kqo6VutjG017+XxZQp0hPHmfmDxYkDvlaLeoZpP2NkpwZ1p4TL2MSCr2Ibl6uTWvc=
  - secure: XEQY8s7p65lWWOuKbVDdTh6ZJtRTJ74Zw3H/+2Ms6vjZhFZsdUJjGo66LW6YvlhmYDXgiPB9piYQGcrGgT3hXJwXoge6n1pdixnV250J0T0dIZMbXYTWTARxDsyq48+LgUuF3pgqvqDWhBcemrePWv48q7fs/mwzuFSOyc8QwLk=
  matrix:
  matrix:
  - ANDROID_TARGET=android-19 ANDROID_ABI=armeabi-v7a
  - ANDROID_TARGET=android-19 ANDROID_ABI=armeabi-v7a
+148 −3
Original line number Original line Diff line number Diff line
@@ -31,6 +31,9 @@ import com.owncloud.android.lib.common.operations.RemoteOperationResult.ResultCo
import com.owncloud.android.lib.resources.shares.ShareType;
import com.owncloud.android.lib.resources.shares.ShareType;
import com.owncloud.android.lib.test_project.TestActivity;
import com.owncloud.android.lib.test_project.TestActivity;


/**
 * Test Create Share: the server must support SHARE API
 */
public class CreateShareTest extends RemoteTest {
public class CreateShareTest extends RemoteTest {


	private static final String LOG_TAG = CreateShareTest.class.getCanonicalName();
	private static final String LOG_TAG = CreateShareTest.class.getCanonicalName();
@@ -38,8 +41,12 @@ public class CreateShareTest extends RemoteTest {
	/* File to share.*/
	/* File to share.*/
	private static final String FILE_TO_SHARE = "/fileToShare.txt";
	private static final String FILE_TO_SHARE = "/fileToShare.txt";


	/* Non-existent file*/
	private static final String NON_EXISTENT_FILE = "/nonExistentFile.txt";
	
	private TestActivity mActivity;
	private TestActivity mActivity;
	private String mFullPath2FileToShare;
	private String mFullPath2FileToShare;
	private String mFullPath2NonExistentFile;
	
	
	@Override
	@Override
	protected void setUp() throws Exception {
	protected void setUp() throws Exception {
@@ -47,6 +54,7 @@ public class CreateShareTest extends RemoteTest {
	    setActivityInitialTouchMode(false);
	    setActivityInitialTouchMode(false);
	    mActivity = getActivity();
	    mActivity = getActivity();
	    mFullPath2FileToShare = mBaseFolderPath + FILE_TO_SHARE;
	    mFullPath2FileToShare = mBaseFolderPath + FILE_TO_SHARE;
	    mFullPath2NonExistentFile = mBaseFolderPath + NON_EXISTENT_FILE;
	    		
	    		
		File textFile = mActivity.extractAsset(TestActivity.ASSETS__TEXT_FILE_NAME);
		File textFile = mActivity.extractAsset(TestActivity.ASSETS__TEXT_FILE_NAME);
		RemoteOperationResult result = mActivity.uploadFile(
		RemoteOperationResult result = mActivity.uploadFile(
@@ -59,9 +67,11 @@ public class CreateShareTest extends RemoteTest {
	}
	}


	/**
	/**
	 * Test Create Share: the server must support SHARE API
	 * Test creation of public shares
	 */
	 */
	public void testCreatePublicShare() {
	public void testCreatePublicShare() {

		/// Successful cases
		RemoteOperationResult result = mActivity.createShare(
		RemoteOperationResult result = mActivity.createShare(
				mFullPath2FileToShare, 
				mFullPath2FileToShare, 
				ShareType.PUBLIC_LINK, 
				ShareType.PUBLIC_LINK, 
@@ -70,6 +80,141 @@ public class CreateShareTest extends RemoteTest {
				"", 
				"", 
				1);
				1);
		assertTrue(result.isSuccess());
		assertTrue(result.isSuccess());
		
		/// Failed cases
		
		// file doesn't exist
		result = mActivity.createShare(
				mFullPath2NonExistentFile, 
				ShareType.PUBLIC_LINK, 
				"", 
				false, 
				"", 
				1);
		assertFalse(result.isSuccess());
		assertEquals(
				RemoteOperationResult.ResultCode.SHARE_NOT_FOUND, 
				result.getCode()
		);
		assertTrue(		// error message from server as part of the result
				result.getData().size() == 1 && 
				result.getData().get(0) instanceof String
		);
		
	}
	
	
	/**
	 * Test creation of private shares with groups
	 */
	public void testCreatePrivateShareWithUser() {
		
		/// Successful cases
		RemoteOperationResult result = mActivity.createShare(
				mFullPath2FileToShare, 
				ShareType.USER, 
				"admin", 
				false, 
				"", 
				31);
		assertTrue(result.isSuccess());
		
		
		/// Failed cases
		
		// sharee doesn't exist
		result = mActivity.createShare(
				mFullPath2FileToShare, 
				ShareType.USER, 
				"no_exist", 
				false, 
				"", 
				31);
		assertFalse(result.isSuccess());
		assertEquals(
				RemoteOperationResult.ResultCode.SHARE_WRONG_PARAMETER, 
				result.getCode()
		);
		assertTrue(		// error message from server as part of the result
				result.getData().size() == 1 && 
				result.getData().get(0) instanceof String
		);
		
		// file doesn't exist
		result = mActivity.createShare(
				mFullPath2NonExistentFile, 
				ShareType.USER, 
				"admin", 
				false, 
				"", 
				31);
		assertFalse(result.isSuccess());
		assertEquals(
				RemoteOperationResult.ResultCode.SHARE_NOT_FOUND, 
				result.getCode()
		);
		assertTrue(		// error message from server as part of the result
				result.getData().size() == 1 && 
				result.getData().get(0) instanceof String
		);
		
	}
	
	
	/**
	 * Test creation of private shares with groups
	 */
	public void testCreatePrivateShareWithGroup() {
		
		/// Successful cases
		RemoteOperationResult result = mActivity.createShare(
				mFullPath2FileToShare, 
				ShareType.GROUP, 
				"admin", 
				false, 
				"", 
				1);
		assertTrue(result.isSuccess());
		
		
		/// Failed cases
		
		// sharee doesn't exist
		result = mActivity.createShare(
				mFullPath2FileToShare, 
				ShareType.GROUP, 
				"no_exist", 
				false, 
				"", 
				31);
		assertFalse(result.isSuccess());
		assertEquals(
				RemoteOperationResult.ResultCode.SHARE_WRONG_PARAMETER, 
				result.getCode()
		);
		assertTrue(		// error message from server as part of the result
				result.getData().size() == 1 && 
				result.getData().get(0) instanceof String
		);
		
		// file doesn't exist
		result = mActivity.createShare(
				mFullPath2NonExistentFile, 
				ShareType.GROUP, 
				"admin", 
				false, 
				"", 
				31);
		assertFalse(result.isSuccess());
		assertEquals(
				RemoteOperationResult.ResultCode.SHARE_NOT_FOUND, 
				result.getCode()
		);
		assertTrue(		// error message from server as part of the result
				result.getData().size() == 1 && 
				result.getData().get(0) instanceof String
		);
		
	}
	}
	
	
	
	
+228 −0
Original line number Original line Diff line number Diff line
/* ownCloud Android Library is available under MIT license
 *   @author David A. Velasco
 *   Copyright (C) 2015 ownCloud Inc.
 *   
 *   Permission is hereby granted, free of charge, to any person obtaining a copy
 *   of this software and associated documentation files (the "Software"), to deal
 *   in the Software without restriction, including without limitation the rights
 *   to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 *   copies of the Software, and to permit persons to whom the Software is
 *   furnished to do so, subject to the following conditions:
 *   
 *   The above copyright notice and this permission notice shall be included in
 *   all copies or substantial portions of the Software.
 *   
 *   THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 
 *   EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 *   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 
 *   NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS 
 *   BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN 
 *   ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 
 *   CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 *   THE SOFTWARE.
 *
 */

package com.owncloud.android.lib.test_project.test;

import java.security.GeneralSecurityException;

import junit.framework.AssertionFailedError;

import org.apache.commons.httpclient.HttpStatus;
import org.apache.commons.httpclient.protocol.Protocol;
import org.apache.commons.httpclient.protocol.ProtocolSocketFactory;
import org.json.JSONException;
import org.json.JSONObject;

import com.owncloud.android.lib.common.OwnCloudClient;
import com.owncloud.android.lib.common.OwnCloudClientFactory;
import com.owncloud.android.lib.common.OwnCloudCredentialsFactory;
import com.owncloud.android.lib.common.network.NetworkUtils;
import com.owncloud.android.lib.common.operations.RemoteOperationResult;
import com.owncloud.android.lib.resources.shares.GetRemoteShareesOperation;
import com.owncloud.android.lib.test_project.R;
import com.owncloud.android.lib.test_project.SelfSignedConfidentSslSocketFactory;

import android.content.Context;
import android.net.Uri;
import android.util.Log;

/**
 * Class to test GetRemoteShareesOperation
 *
 * With this TestCase we are experimenting a bit to improve the test suite design, in two aspects:
 * 
 *  - Reduce the dependency from the set of test cases on the "test project" needed to 
 *  have an instrumented APK to install in the device, as required by the testing framework
 *  provided by Android. To get there, this class avoids calling TestActivity methods in the test 
 *  method.
 *  
 *  - Reduce the impact of creating a remote fixture over the Internet, while the structure of the 
 *  TestCase is kept easy to maintain. To get this, all the tests are done in a single test method, 
 *  granting this way that setUp and tearDown are run only once.
 *
 */

public class GetShareesTest extends RemoteTest {

	private static final String LOG_TAG = GetShareesTest.class.getCanonicalName();
		
	String mServerUri, mUser, mPass;
	OwnCloudClient mClient = null;
	
	public GetShareesTest() {
		super();
		
		Protocol pr = Protocol.getProtocol("https");
		if (pr == null || !(pr.getSocketFactory() instanceof SelfSignedConfidentSslSocketFactory)) {
			try {
				ProtocolSocketFactory psf = new SelfSignedConfidentSslSocketFactory();
				Protocol.registerProtocol(
						"https",
						new Protocol("https", psf, 443));
				
			} catch (GeneralSecurityException e) {
				throw new AssertionFailedError(
						"Self-signed confident SSL context could not be loaded");
			}
		}
		
	}


	protected Context getContext() {
		return getActivity();
	}
	
	@Override
	protected void setUp() throws Exception {
	    super.setUp();

	    // Next initialization cannot be done in the constructor because getContext() is not 
	    // ready yet, returns NULL.
	    initAccessToServer(getContext());
	    
	    Log.v(LOG_TAG, "Setting up the remote fixture...");
	    
		Log.v(LOG_TAG, "Remote fixture created.");
		
	}


	/**
	 *  Test get sharees
	 * 
	 *  Requires OC server 8.2 or later
	 */
	public void testGetRemoteShareesOperation() {
		Log.v(LOG_TAG, "testGetRemoteSharees in");

		/// successful cases

		// search for sharees including "a"
		GetRemoteShareesOperation getShareesOperation = new GetRemoteShareesOperation("a", 1, 50);
		RemoteOperationResult result = getShareesOperation.execute(mClient);
		JSONObject resultItem;
		JSONObject value;
		byte type;
		int userCount = 0, groupCount = 0;
		assertTrue(result.isSuccess() && result.getData().size() == 3);
		try {
			for (int i=0; i<3; i++) {
				resultItem = (JSONObject) result.getData().get(i);
	            value = resultItem.getJSONObject(GetRemoteShareesOperation.NODE_VALUE);
	            type = (byte) value.getInt(GetRemoteShareesOperation.PROPERTY_SHARE_TYPE);
				if (GetRemoteShareesOperation.GROUP_TYPE.equals(type)) {
					groupCount++;
				} else {
					userCount++;
				}
			}
			assertEquals(userCount, 2);
			assertEquals(groupCount, 1);
		} catch (JSONException e) {
			AssertionFailedError afe = new AssertionFailedError(e.getLocalizedMessage());
			afe.setStackTrace(e.getStackTrace());
			throw afe;
		}
		
		// search for sharees including "ad"
		getShareesOperation = new GetRemoteShareesOperation("ad", 1, 50);
		result = getShareesOperation.execute(mClient);
		assertTrue(result.isSuccess() && result.getData().size() == 2);
		userCount = 0; groupCount = 0;
		try {
			for (int i=0; i<2; i++) {
				resultItem = (JSONObject) result.getData().get(i);
	            value = resultItem.getJSONObject(GetRemoteShareesOperation.NODE_VALUE);
	            type = (byte) value.getInt(GetRemoteShareesOperation.PROPERTY_SHARE_TYPE);
				if (GetRemoteShareesOperation.GROUP_TYPE.equals(type)) {
					groupCount++;
				} else {
					userCount++;
				}
			}
			assertEquals(userCount, 1);
			assertEquals(groupCount, 1);
		} catch (JSONException e) {
			AssertionFailedError afe = new AssertionFailedError(e.getLocalizedMessage());
			afe.setStackTrace(e.getStackTrace());
			throw afe;
		}
		
		
		// search for sharees including "b"
		getShareesOperation = new GetRemoteShareesOperation("b", 1, 50);
		result = getShareesOperation.execute(mClient);
		assertTrue(result.isSuccess() && result.getData().size() == 0);
		
		
		/// failed cases
		
		// search for sharees including wrong page values
		getShareesOperation = new GetRemoteShareesOperation("a", 0, 50);
		result = getShareesOperation.execute(mClient);
		assertTrue(!result.isSuccess() && result.getHttpCode() == HttpStatus.SC_BAD_REQUEST);
		
		getShareesOperation = new GetRemoteShareesOperation("a", 1, 0);
		result = getShareesOperation.execute(mClient);
		assertTrue(!result.isSuccess() && result.getHttpCode() == HttpStatus.SC_BAD_REQUEST);
	}
	
	@Override
	protected void tearDown() throws Exception {
	    Log.v(LOG_TAG, "Deleting remote fixture...");
		super.tearDown();
	    Log.v(LOG_TAG, "Remote fixture delete.");
	}

	
	private void initAccessToServer(Context context) {
	    Log.v(LOG_TAG, "Setting up client instance to access OC server...");
		
		mServerUri = context.getString(R.string.server_base_url);
		mUser = context.getString(R.string.username);
		mPass = context.getString(R.string.password);
		
		mClient = new OwnCloudClient(
				Uri.parse(mServerUri), 
				NetworkUtils.getMultiThreadedConnManager()
		);
		mClient.setDefaultTimeouts(
				OwnCloudClientFactory.DEFAULT_DATA_TIMEOUT, 
				OwnCloudClientFactory.DEFAULT_CONNECTION_TIMEOUT);
		mClient.setFollowRedirects(true);
		mClient.setCredentials(
				OwnCloudCredentialsFactory.newBasicCredentials(
						mUser, 
						mPass
				)
		);
		
	    Log.v(LOG_TAG, "Client instance set up.");
	    
	}
	
	
}