blob: 919ac39c9d447a0a1fc12d52a56a73fc528e5753 [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 Hirono8ba41912015-07-30 21:22:57 +090048 public void testReadDocument_basic() throws Exception {
Daichi Hirono3faa43a2015-08-05 17:15:35 +090049 mtpManager.setImportFileBytes(0, 1, HELLO_BYTES);
Daichi Hirono84dfb052015-08-31 12:32:39 +090050 final ParcelFileDescriptor descriptor = mPipeManager.readDocument(
Daichi Hirono6a5ea7e2016-02-02 16:35:03 +090051 mtpManager,
52 new Identifier(0, 0, 1, null, MtpDatabaseConstants.DOCUMENT_TYPE_OBJECT));
Daichi Hirono3faa43a2015-08-05 17:15:35 +090053 assertDescriptor(descriptor, HELLO_BYTES);
54 }
55
56 public void testReadDocument_error() throws Exception {
Daichi Hirono6a5ea7e2016-02-02 16:35:03 +090057 final ParcelFileDescriptor descriptor = mPipeManager.readDocument(
58 mtpManager,
59 new Identifier(0, 0, 1, null, MtpDatabaseConstants.DOCUMENT_TYPE_OBJECT));
Daichi Hirono3faa43a2015-08-05 17:15:35 +090060 assertDescriptorError(descriptor);
61 }
62
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090063 public void testWriteDocument_basic() throws Exception {
Daichi Hironof578fa22016-02-19 18:05:42 +090064 TestUtil.addTestDevice(mDatabase);
65 TestUtil.addTestStorage(mDatabase, "1");
66
67 final MtpObjectInfo info =
68 new MtpObjectInfo.Builder().setObjectHandle(1).setName("note.txt").build();
69 mDatabase.getMapper().startAddingDocuments("2");
Daichi Hirono61ba9232016-02-26 12:58:39 +090070 mDatabase.getMapper().putChildDocuments(
71 0, "2", TestUtil.OPERATIONS_SUPPORTED,
72 new MtpObjectInfo[] { info });
Daichi Hironof578fa22016-02-19 18:05:42 +090073 mDatabase.getMapper().stopAddingDocuments("2");
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090074 // Create a placeholder file which should be replaced by a real file later.
Daichi Hironof578fa22016-02-19 18:05:42 +090075 mtpManager.setObjectInfo(0, info);
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090076
77 // Upload testing bytes.
Tomasz Mikolajewski3edb4202015-08-31 13:25:59 +090078 final ParcelFileDescriptor descriptor = mPipeManager.writeDocument(
Daichi Hirono6a5ea7e2016-02-02 16:35:03 +090079 getContext(),
80 mtpManager,
Daichi Hirono61ba9232016-02-26 12:58:39 +090081 new Identifier(0, 0, 1, "2", MtpDatabaseConstants.DOCUMENT_TYPE_OBJECT),
82 TestUtil.OPERATIONS_SUPPORTED);
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090083 final ParcelFileDescriptor.AutoCloseOutputStream outputStream =
84 new ParcelFileDescriptor.AutoCloseOutputStream(descriptor);
85 outputStream.write(HELLO_BYTES, 0, HELLO_BYTES.length);
86 outputStream.close();
Daichi Hironof578fa22016-02-19 18:05:42 +090087 mExecutor.shutdown();
88 assertTrue(mExecutor.awaitTermination(1000, TimeUnit.MILLISECONDS));
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090089
90 // Check if the placeholder file is removed.
91 try {
Daichi Hironof578fa22016-02-19 18:05:42 +090092 mtpManager.getObjectInfo(0, 1);
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +090093 fail(); // The placeholder file has not been deleted.
94 } catch (IOException e) {
95 // Expected error, as the file is gone.
96 }
97
98 // Confirm that the target file is created.
Tomasz Mikolajewskibb430fa2015-08-25 18:34:30 +090099 final MtpObjectInfo targetDocument = mtpManager.getObjectInfo(
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +0900100 0, TestMtpManager.CREATED_DOCUMENT_HANDLE);
101 assertTrue(targetDocument != null);
102
Daichi Hironof578fa22016-02-19 18:05:42 +0900103 // Confirm the object handle is updated.
104 try (final Cursor cursor = mDatabase.queryDocument(
105 "2", new String[] { MtpDatabaseConstants.COLUMN_OBJECT_HANDLE })) {
106 assertEquals(1, cursor.getCount());
107 cursor.moveToNext();
108 assertEquals(TestMtpManager.CREATED_DOCUMENT_HANDLE, cursor.getInt(0));
109 }
110
Tomasz Mikolajewskib80a3cf2015-08-24 16:10:51 +0900111 // Verify uploaded bytes.
112 final byte[] uploadedBytes = mtpManager.getImportFileBytes(
113 0, TestMtpManager.CREATED_DOCUMENT_HANDLE);
114 assertEquals(HELLO_BYTES.length, uploadedBytes.length);
115 for (int i = 0; i < HELLO_BYTES.length; i++) {
116 assertEquals(HELLO_BYTES[i], uploadedBytes[i]);
117 }
118 }
119
Daichi Hirono3faa43a2015-08-05 17:15:35 +0900120 public void testReadThumbnail_basic() throws Exception {
121 mtpManager.setThumbnail(0, 1, HELLO_BYTES);
Daichi Hirono84dfb052015-08-31 12:32:39 +0900122 final ParcelFileDescriptor descriptor = mPipeManager.readThumbnail(
Daichi Hirono6a5ea7e2016-02-02 16:35:03 +0900123 mtpManager,
124 new Identifier(0, 0, 1, null, MtpDatabaseConstants.DOCUMENT_TYPE_OBJECT));
Daichi Hirono3faa43a2015-08-05 17:15:35 +0900125 assertDescriptor(descriptor, HELLO_BYTES);
126 }
127
128 public void testReadThumbnail_error() throws Exception {
Daichi Hirono6a5ea7e2016-02-02 16:35:03 +0900129 final ParcelFileDescriptor descriptor = mPipeManager.readThumbnail(
130 mtpManager,
131 new Identifier(0, 0, 1, null, MtpDatabaseConstants.DOCUMENT_TYPE_OBJECT));
Daichi Hirono3faa43a2015-08-05 17:15:35 +0900132 assertDescriptorError(descriptor);
133 }
134
135 private void assertDescriptor(ParcelFileDescriptor descriptor, byte[] expectedBytes)
136 throws IOException, InterruptedException {
Daichi Hironof578fa22016-02-19 18:05:42 +0900137 mExecutor.shutdown();
138 assertTrue(mExecutor.awaitTermination(1000, TimeUnit.MILLISECONDS));
Daichi Hirono8ba41912015-07-30 21:22:57 +0900139 try (final ParcelFileDescriptor.AutoCloseInputStream stream =
140 new ParcelFileDescriptor.AutoCloseInputStream(descriptor)) {
Daichi Hirono3faa43a2015-08-05 17:15:35 +0900141 byte[] results = new byte[100];
Tomasz Mikolajewski52652ac2015-08-05 17:33:33 +0900142 assertEquals(expectedBytes.length, stream.read(results));
143 for (int i = 0; i < expectedBytes.length; i++) {
Daichi Hirono8ba41912015-07-30 21:22:57 +0900144 assertEquals(expectedBytes[i], results[i]);
145 }
146 }
147 }
148
Daichi Hirono3faa43a2015-08-05 17:15:35 +0900149 private void assertDescriptorError(ParcelFileDescriptor descriptor)
150 throws InterruptedException {
Daichi Hironof578fa22016-02-19 18:05:42 +0900151 mExecutor.shutdown();
152 assertTrue(mExecutor.awaitTermination(1000, TimeUnit.MILLISECONDS));
Daichi Hirono8ba41912015-07-30 21:22:57 +0900153 try {
154 descriptor.checkError();
155 fail();
156 } catch (Throwable error) {
157 assertTrue(error instanceof IOException);
158 }
159 }
160}