blob: cdddd8178dc9940d156b2168fe1dd83fed03d233 [file] [log] [blame]
Daichi Hirono8ba41912015-07-30 21:22:57 +09001/*
2 * Copyright (C) 2015 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package com.android.mtp;
18
Daichi Hironof578fa22016-02-19 18:05:42 +090019import android.database.Cursor;
Tomasz Mikolajewskibb430fa2015-08-25 18:34:30 +090020import android.mtp.MtpObjectInfo;
Daichi Hirono8ba41912015-07-30 21:22:57 +090021import android.os.ParcelFileDescriptor;
Daichi Hironof578fa22016-02-19 18:05:42 +090022import android.provider.DocumentsContract.Document;
Daichi Hirono8ba41912015-07-30 21:22:57 +090023import android.test.AndroidTestCase;
Daichi Hirono4604b742015-11-12 12:12:48 +090024import android.test.suitebuilder.annotation.MediumTest;
Daichi Hirono8ba41912015-07-30 21:22:57 +090025
26import java.io.IOException;
27import java.util.concurrent.ExecutorService;
28import java.util.concurrent.Executors;
29import java.util.concurrent.TimeUnit;
30
Daichi Hirono4604b742015-11-12 12:12:48 +090031@MediumTest
Daichi Hirono8ba41912015-07-30 21:22:57 +090032public class PipeManagerTest extends AndroidTestCase {
Daichi Hirono3faa43a2015-08-05 17:15:35 +090033 private static final byte[] HELLO_BYTES = new byte[] { 'h', 'e', 'l', 'l', 'o' };
34
35 private TestMtpManager mtpManager;
Daichi Hirono84dfb052015-08-31 12:32:39 +090036 private ExecutorService mExecutor;
37 private PipeManager mPipeManager;
Daichi Hironof578fa22016-02-19 18:05:42 +090038 private MtpDatabase mDatabase;
Daichi Hirono3faa43a2015-08-05 17:15:35 +090039
40 @Override
41 public void setUp() {
42 mtpManager = new TestMtpManager(getContext());
Daichi Hirono84dfb052015-08-31 12:32:39 +090043 mExecutor = Executors.newSingleThreadExecutor();
Daichi Hironof578fa22016-02-19 18:05:42 +090044 mDatabase = new MtpDatabase(getContext(), MtpDatabaseConstants.FLAG_DATABASE_IN_MEMORY);
45 mPipeManager = new PipeManager(mDatabase, mExecutor);
Daichi Hirono3faa43a2015-08-05 17:15:35 +090046 }
47
Daichi Hirono24ab92a2016-03-04 17:53:03 +090048 @Override
49 protected void tearDown() throws Exception {
50 assertTrue(mPipeManager.close());
51 }
52
Daichi Hirono8ba41912015-07-30 21:22:57 +090053 public void testReadDocument_basic() throws Exception {
Daichi Hirono3faa43a2015-08-05 17:15:35 +090054 mtpManager.setImportFileBytes(0, 1, HELLO_BYTES);
Daichi Hirono84dfb052015-08-31 12:32:39 +090055 final ParcelFileDescriptor descriptor = mPipeManager.readDocument(
Daichi Hirono6a5ea7e2016-02-02 16:35:03 +090056 mtpManager,
57 new Identifier(0, 0, 1, null, MtpDatabaseConstants.DOCUMENT_TYPE_OBJECT));
Daichi Hirono3faa43a2015-08-05 17:15:35 +090058 assertDescriptor(descriptor, HELLO_BYTES);
59 }
60
61 public void testReadDocument_error() throws Exception {
Daichi Hirono6a5ea7e2016-02-02 16:35:03 +090062 final ParcelFileDescriptor descriptor = mPipeManager.readDocument(
63 mtpManager,
64 new Identifier(0, 0, 1, null, MtpDatabaseConstants.DOCUMENT_TYPE_OBJECT));
Daichi Hirono3faa43a2015-08-05 17:15:35 +090065 assertDescriptorError(descriptor);
66 }
67
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090068 public void testWriteDocument_basic() throws Exception {
Daichi Hironof578fa22016-02-19 18:05:42 +090069 TestUtil.addTestDevice(mDatabase);
70 TestUtil.addTestStorage(mDatabase, "1");
71
72 final MtpObjectInfo info =
73 new MtpObjectInfo.Builder().setObjectHandle(1).setName("note.txt").build();
74 mDatabase.getMapper().startAddingDocuments("2");
Daichi Hirono61ba9232016-02-26 12:58:39 +090075 mDatabase.getMapper().putChildDocuments(
76 0, "2", TestUtil.OPERATIONS_SUPPORTED,
77 new MtpObjectInfo[] { info });
Daichi Hironof578fa22016-02-19 18:05:42 +090078 mDatabase.getMapper().stopAddingDocuments("2");
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090079 // Create a placeholder file which should be replaced by a real file later.
Daichi Hironof578fa22016-02-19 18:05:42 +090080 mtpManager.setObjectInfo(0, info);
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090081
82 // Upload testing bytes.
Tomasz Mikolajewski3edb4202015-08-31 13:25:59 +090083 final ParcelFileDescriptor descriptor = mPipeManager.writeDocument(
Daichi Hirono6a5ea7e2016-02-02 16:35:03 +090084 getContext(),
85 mtpManager,
Daichi Hirono61ba9232016-02-26 12:58:39 +090086 new Identifier(0, 0, 1, "2", MtpDatabaseConstants.DOCUMENT_TYPE_OBJECT),
87 TestUtil.OPERATIONS_SUPPORTED);
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090088 final ParcelFileDescriptor.AutoCloseOutputStream outputStream =
89 new ParcelFileDescriptor.AutoCloseOutputStream(descriptor);
90 outputStream.write(HELLO_BYTES, 0, HELLO_BYTES.length);
91 outputStream.close();
Daichi Hironof578fa22016-02-19 18:05:42 +090092 mExecutor.shutdown();
93 assertTrue(mExecutor.awaitTermination(1000, TimeUnit.MILLISECONDS));
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090094
95 // Check if the placeholder file is removed.
96 try {
Daichi Hironof578fa22016-02-19 18:05:42 +090097 mtpManager.getObjectInfo(0, 1);
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090098 fail(); // The placeholder file has not been deleted.
99 } catch (IOException e) {
100 // Expected error, as the file is gone.
101 }
102
103 // Confirm that the target file is created.
Tomasz Mikolajewskibb430fa2015-08-25 18:34:30 +0900104 final MtpObjectInfo targetDocument = mtpManager.getObjectInfo(
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +0900105 0, TestMtpManager.CREATED_DOCUMENT_HANDLE);
106 assertTrue(targetDocument != null);
107
Daichi Hironof578fa22016-02-19 18:05:42 +0900108 // Confirm the object handle is updated.
109 try (final Cursor cursor = mDatabase.queryDocument(
110 "2", new String[] { MtpDatabaseConstants.COLUMN_OBJECT_HANDLE })) {
111 assertEquals(1, cursor.getCount());
112 cursor.moveToNext();
113 assertEquals(TestMtpManager.CREATED_DOCUMENT_HANDLE, cursor.getInt(0));
114 }
115
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +0900116 // Verify uploaded bytes.
117 final byte[] uploadedBytes = mtpManager.getImportFileBytes(
118 0, TestMtpManager.CREATED_DOCUMENT_HANDLE);
119 assertEquals(HELLO_BYTES.length, uploadedBytes.length);
120 for (int i = 0; i < HELLO_BYTES.length; i++) {
121 assertEquals(HELLO_BYTES[i], uploadedBytes[i]);
122 }
123 }
124
Daichi Hirono3faa43a2015-08-05 17:15:35 +0900125 public void testReadThumbnail_basic() throws Exception {
126 mtpManager.setThumbnail(0, 1, HELLO_BYTES);
Daichi Hirono84dfb052015-08-31 12:32:39 +0900127 final ParcelFileDescriptor descriptor = mPipeManager.readThumbnail(
Daichi Hirono6a5ea7e2016-02-02 16:35:03 +0900128 mtpManager,
129 new Identifier(0, 0, 1, null, MtpDatabaseConstants.DOCUMENT_TYPE_OBJECT));
Daichi Hirono3faa43a2015-08-05 17:15:35 +0900130 assertDescriptor(descriptor, HELLO_BYTES);
131 }
132
133 public void testReadThumbnail_error() throws Exception {
Daichi Hirono6a5ea7e2016-02-02 16:35:03 +0900134 final ParcelFileDescriptor descriptor = mPipeManager.readThumbnail(
135 mtpManager,
136 new Identifier(0, 0, 1, null, MtpDatabaseConstants.DOCUMENT_TYPE_OBJECT));
Daichi Hirono3faa43a2015-08-05 17:15:35 +0900137 assertDescriptorError(descriptor);
138 }
139
140 private void assertDescriptor(ParcelFileDescriptor descriptor, byte[] expectedBytes)
141 throws IOException, InterruptedException {
Daichi Hironof578fa22016-02-19 18:05:42 +0900142 mExecutor.shutdown();
143 assertTrue(mExecutor.awaitTermination(1000, TimeUnit.MILLISECONDS));
Daichi Hirono8ba41912015-07-30 21:22:57 +0900144 try (final ParcelFileDescriptor.AutoCloseInputStream stream =
145 new ParcelFileDescriptor.AutoCloseInputStream(descriptor)) {
Daichi Hirono3faa43a2015-08-05 17:15:35 +0900146 byte[] results = new byte[100];
Tomasz Mikolajewski52652ac2015-08-05 17:33:33 +0900147 assertEquals(expectedBytes.length, stream.read(results));
148 for (int i = 0; i < expectedBytes.length; i++) {
Daichi Hirono8ba41912015-07-30 21:22:57 +0900149 assertEquals(expectedBytes[i], results[i]);
150 }
151 }
152 }
153
Daichi Hirono3faa43a2015-08-05 17:15:35 +0900154 private void assertDescriptorError(ParcelFileDescriptor descriptor)
155 throws InterruptedException {
Daichi Hironof578fa22016-02-19 18:05:42 +0900156 mExecutor.shutdown();
157 assertTrue(mExecutor.awaitTermination(1000, TimeUnit.MILLISECONDS));
Daichi Hirono8ba41912015-07-30 21:22:57 +0900158 try {
159 descriptor.checkError();
160 fail();
161 } catch (Throwable error) {
162 assertTrue(error instanceof IOException);
163 }
164 }
165}