mirror of
				https://github.com/owncloud/android-library.git
				synced 2025-10-30 18:07:38 +00:00 
			
		
		
		
	Updated automatic tests to cover share permissions updates
This commit is contained in:
		
							parent
							
								
									275c042f78
								
							
						
					
					
						commit
						b3535a3678
					
				| @ -0,0 +1,252 @@ | |||||||
|  | /* ownCloud Android Library is available under MIT license | ||||||
|  |  *   @author masensio | ||||||
|  |  *   @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.io.File; | ||||||
|  | import java.security.GeneralSecurityException; | ||||||
|  | import java.util.Calendar; | ||||||
|  | 
 | ||||||
|  | import junit.framework.AssertionFailedError; | ||||||
|  | 
 | ||||||
|  | import org.apache.commons.httpclient.protocol.Protocol; | ||||||
|  | import org.apache.commons.httpclient.protocol.ProtocolSocketFactory; | ||||||
|  | 
 | ||||||
|  | import android.content.Context; | ||||||
|  | import android.net.Uri; | ||||||
|  | import android.util.Log; | ||||||
|  | 
 | ||||||
|  | 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.common.operations.RemoteOperationResult.ResultCode; | ||||||
|  | import com.owncloud.android.lib.resources.shares.OCShare; | ||||||
|  | import com.owncloud.android.lib.resources.shares.RemoveRemoteShareOperation; | ||||||
|  | import com.owncloud.android.lib.resources.shares.ShareType; | ||||||
|  | import com.owncloud.android.lib.resources.shares.UpdateRemoteShareOperation; | ||||||
|  | import com.owncloud.android.lib.test_project.R; | ||||||
|  | import com.owncloud.android.lib.test_project.SelfSignedConfidentSslSocketFactory; | ||||||
|  | import com.owncloud.android.lib.test_project.TestActivity; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * Class to test UpdateRemoteShareOperation | ||||||
|  |  * with private shares | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  | public class UpdatePrivateShareTest extends RemoteTest { | ||||||
|  | 	private static final String LOG_TAG = UpdatePrivateShareTest.class.getCanonicalName(); | ||||||
|  | 	 | ||||||
|  | 	/* File to share and update */ | ||||||
|  | 	private static final String FILE_TO_SHARE = "/fileToShare.txt"; | ||||||
|  | 
 | ||||||
|  | 	/* Folder to share and update */ | ||||||
|  | 	private static final String FOLDER_TO_SHARE = "/folderToShare"; | ||||||
|  | 
 | ||||||
|  | 	/* Sharees */ | ||||||
|  | 	private static final String USER_SHAREE = "admin"; | ||||||
|  | 	private static final String GROUP_SHAREE = "admin"; | ||||||
|  | 
 | ||||||
|  | 	private String mFullPath2FileToShare; | ||||||
|  | 	private String mFullPath2FolderToShare; | ||||||
|  | 
 | ||||||
|  | 	private OCShare mFileShare; | ||||||
|  | 	private OCShare mFolderShare; | ||||||
|  | 
 | ||||||
|  | 	String mServerUri, mUser, mPass; | ||||||
|  | 	OwnCloudClient mClient = null; | ||||||
|  | 	 | ||||||
|  | 	public UpdatePrivateShareTest(){ | ||||||
|  | 		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..."); | ||||||
|  | 	     | ||||||
|  | 	    // Upload the file | ||||||
|  | 	    mFullPath2FileToShare = mBaseFolderPath + FILE_TO_SHARE; | ||||||
|  | 	     | ||||||
|  | 	    File textFile = getActivity().extractAsset(TestActivity.ASSETS__TEXT_FILE_NAME); | ||||||
|  | 		RemoteOperationResult result = getActivity().uploadFile( | ||||||
|  | 				textFile.getAbsolutePath(),  | ||||||
|  | 				mFullPath2FileToShare,  | ||||||
|  | 				"txt/plain"); | ||||||
|  | 		if (!result.isSuccess()) { | ||||||
|  | 			Utils.logAndThrow(LOG_TAG, result); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		// Share the file privately with other user | ||||||
|  | 		result = getActivity().createShare( | ||||||
|  | 				mFullPath2FileToShare,  | ||||||
|  | 				ShareType.USER, | ||||||
|  | 				USER_SHAREE, | ||||||
|  | 				false,  | ||||||
|  | 				"",  | ||||||
|  | 				OCShare.MAXIMUM_PERMISSIONS_FOR_FILE); | ||||||
|  | 
 | ||||||
|  | 	    if (result.isSuccess()){ | ||||||
|  | 	    	mFileShare = (OCShare) result.getData().get(0); | ||||||
|  | 	    } else{ | ||||||
|  | 	    	mFileShare = null; | ||||||
|  | 	    } | ||||||
|  | 
 | ||||||
|  | 		// Create the folder | ||||||
|  | 		mFullPath2FolderToShare = mBaseFolderPath + FOLDER_TO_SHARE; | ||||||
|  | 		result = getActivity().createFolder( | ||||||
|  | 				mFullPath2FolderToShare, | ||||||
|  | 				true); | ||||||
|  | 		if (!result.isSuccess()) { | ||||||
|  | 			Utils.logAndThrow(LOG_TAG, result); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		// Share the folder privately with a group | ||||||
|  | 		result = getActivity().createShare( | ||||||
|  | 				mFullPath2FolderToShare, | ||||||
|  | 				ShareType.GROUP, | ||||||
|  | 				GROUP_SHAREE, | ||||||
|  | 				false, | ||||||
|  | 				"", | ||||||
|  | 				OCShare.MAXIMUM_PERMISSIONS_FOR_FOLDER); | ||||||
|  | 
 | ||||||
|  | 		if (result.isSuccess()){ | ||||||
|  | 			mFolderShare = (OCShare) result.getData().get(0); | ||||||
|  | 		} else{ | ||||||
|  | 			mFolderShare = null; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		Log.v(LOG_TAG, "Remote fixture created."); | ||||||
|  | 		 | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	 | ||||||
|  | 	public void testUpdateSharePermissions() { | ||||||
|  | 		Log.v(LOG_TAG, "testUpdateSharePermissions in"); | ||||||
|  | 		 | ||||||
|  | 		if (mFileShare != null) { | ||||||
|  | 			/// successful tests | ||||||
|  | 			// Update Share permissions on a shared file | ||||||
|  | 			UpdateRemoteShareOperation updateShare = new UpdateRemoteShareOperation(mFileShare.getRemoteId()); | ||||||
|  | 			updateShare.setPermissions(OCShare.READ_PERMISSION_FLAG);	// minimum permissions | ||||||
|  | 			RemoteOperationResult result = updateShare.execute(mClient); | ||||||
|  | 			assertTrue(result.isSuccess()); | ||||||
|  | 
 | ||||||
|  | 			// Update Share permissions on a shared folder | ||||||
|  | 			updateShare = new UpdateRemoteShareOperation(mFolderShare.getRemoteId()); | ||||||
|  | 			updateShare.setPermissions(OCShare.READ_PERMISSION_FLAG + OCShare.DELETE_PERMISSION_FLAG); | ||||||
|  | 			result = updateShare.execute(mClient); | ||||||
|  | 			assertTrue(result.isSuccess()); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 			/// unsuccessful tests | ||||||
|  | 			// Update Share with invalid permissions | ||||||
|  | 			updateShare = new UpdateRemoteShareOperation(mFileShare.getRemoteId()); | ||||||
|  | 			updateShare.setPermissions(OCShare.MAXIMUM_PERMISSIONS_FOR_FOLDER + 1); // greater than maximum value | ||||||
|  | 			result = updateShare.execute(mClient); | ||||||
|  | 			assertFalse(result.isSuccess()); | ||||||
|  | 
 | ||||||
|  | 			// Unshare the file before next unsuccessful tests | ||||||
|  | 			RemoveRemoteShareOperation unshare = new RemoveRemoteShareOperation((int) mFileShare.getRemoteId()); | ||||||
|  | 			result = unshare.execute(mClient); | ||||||
|  | 			 | ||||||
|  | 			if (result.isSuccess()) {				 | ||||||
|  | 				// Update Share permissions on unknown share | ||||||
|  | 				UpdateRemoteShareOperation updateNoShare = new UpdateRemoteShareOperation(mFileShare.getRemoteId()); | ||||||
|  | 				updateShare.setPermissions(OCShare.READ_PERMISSION_FLAG);	// minimum permissions | ||||||
|  | 				result = updateShare.execute(mClient); | ||||||
|  | 				assertFalse(result.isSuccess()); | ||||||
|  | 			} | ||||||
|  | 				 | ||||||
|  | 		} 		 | ||||||
|  | 		 | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	@Override | ||||||
|  | 	protected void tearDown() throws Exception { | ||||||
|  | 	    Log.v(LOG_TAG, "Deleting remote fixture..."); | ||||||
|  | 		if (mFullPath2FileToShare != null) { | ||||||
|  | 			RemoteOperationResult removeResult = getActivity().removeFile(mFullPath2FileToShare); | ||||||
|  | 			if (!removeResult.isSuccess() && removeResult.getCode() != ResultCode.TIMEOUT) { | ||||||
|  | 				Utils.logAndThrow(LOG_TAG, removeResult); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		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."); | ||||||
|  | 	     | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -1,5 +1,6 @@ | |||||||
| /* ownCloud Android Library is available under MIT license | /* ownCloud Android Library is available under MIT license | ||||||
|  *   @author masensio |  *   @author masensio | ||||||
|  |  *   @author David A. Velasco | ||||||
|  *   Copyright (C) 2015 ownCloud Inc. |  *   Copyright (C) 2015 ownCloud Inc. | ||||||
|  *    |  *    | ||||||
|  *   Permission is hereby granted, free of charge, to any person obtaining a copy |  *   Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
| @ -54,17 +55,18 @@ import com.owncloud.android.lib.test_project.TestActivity; | |||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * Class to test UpdateRemoteShareOperation |  * Class to test UpdateRemoteShareOperation | ||||||
|  |  * with public shares | ||||||
|  * |  * | ||||||
|  */ |  */ | ||||||
| public class UpdateShareTest extends RemoteTest { | public class UpdatePublicShareTest extends RemoteTest { | ||||||
| 	private static final String LOG_TAG = UpdateShareTest.class.getCanonicalName(); | 	private static final String LOG_TAG = UpdatePublicShareTest.class.getCanonicalName(); | ||||||
| 	 | 	 | ||||||
| 	/* File to share and update.*/ | 	/* File to share and update.*/ | ||||||
| 	private static final String FILE_TO_SHARE = "/fileToShare.txt"; | 	private static final String FILE_TO_SHARE = "/fileToShare.txt"; | ||||||
| 	 | 	 | ||||||
| 	// Data for tests  | 	// Data for tests  | ||||||
| 	private static final String PASSWORD = "password"; | 	private static final String PASSWORD = "password"; | ||||||
| 	private static final String PASS_SPECIAL_CHARS = "p@sswórd"; | 	private static final String PASS_SPECIAL_CHARS = "p@ssw<EFBFBD>rd"; | ||||||
| 	 | 	 | ||||||
| 	private String mFullPath2FileToShare; | 	private String mFullPath2FileToShare; | ||||||
| 	 | 	 | ||||||
| @ -73,7 +75,7 @@ public class UpdateShareTest extends RemoteTest { | |||||||
| 	String mServerUri, mUser, mPass; | 	String mServerUri, mUser, mPass; | ||||||
| 	OwnCloudClient mClient = null; | 	OwnCloudClient mClient = null; | ||||||
| 	 | 	 | ||||||
| 	public UpdateShareTest(){ | 	public UpdatePublicShareTest(){ | ||||||
| 		super(); | 		super(); | ||||||
| 		 | 		 | ||||||
| 		Protocol pr = Protocol.getProtocol("https"); | 		Protocol pr = Protocol.getProtocol("https"); | ||||||
| @ -117,7 +119,7 @@ public class UpdateShareTest extends RemoteTest { | |||||||
| 			Utils.logAndThrow(LOG_TAG, result); | 			Utils.logAndThrow(LOG_TAG, result); | ||||||
| 		}	     | 		}	     | ||||||
| 		 | 		 | ||||||
| 		// Share the file | 		// Share the file with a public link | ||||||
| 		result = getActivity().createShare( | 		result = getActivity().createShare( | ||||||
| 				mFullPath2FileToShare,  | 				mFullPath2FileToShare,  | ||||||
| 				ShareType.PUBLIC_LINK,  | 				ShareType.PUBLIC_LINK,  | ||||||
| @ -137,8 +139,8 @@ public class UpdateShareTest extends RemoteTest { | |||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	 | 	 | ||||||
| 	public void testUpdateRemoteShareOperation() { | 	public void testUpdatePublicShare() { | ||||||
| 		Log.v(LOG_TAG, "testUpdateShare in"); | 		Log.v(LOG_TAG, "testUpdatePublicShare in"); | ||||||
| 		 | 		 | ||||||
| 		if (mShare != null) { | 		if (mShare != null) { | ||||||
| 			// successful tests | 			// successful tests | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user