1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
/***************************************************************************************************
* Copyright © All Contributors. See LICENSE and AUTHORS in the root directory for details.
**************************************************************************************************/
package at.bitfire.vcard4android.contactrow
import android.Manifest
import android.accounts.Account
import android.content.ContentProviderClient
import android.content.ContentUris
import android.content.ContentValues
import android.provider.ContactsContract
import android.provider.ContactsContract.CommonDataKinds.Photo
import android.provider.ContactsContract.RawContacts
import androidx.test.platform.app.InstrumentationRegistry
import androidx.test.rule.GrantPermissionRule
import at.bitfire.vcard4android.AndroidContact
import at.bitfire.vcard4android.Contact
import at.bitfire.vcard4android.impl.TestAddressBook
import org.apache.commons.io.IOUtils
import org.junit.Assert
import org.junit.Assert.*
import org.junit.BeforeClass
import org.junit.ClassRule
import org.junit.Test
import kotlin.random.Random
class PhotoHandlerTest {
companion object {
@JvmField
@ClassRule
val permissionRule = GrantPermissionRule.grant(Manifest.permission.READ_CONTACTS, Manifest.permission.WRITE_CONTACTS)!!
private val testAccount = Account("AndroidContactTest", "at.bitfire.vcard4android")
val testContext = InstrumentationRegistry.getInstrumentation().context
private lateinit var provider: ContentProviderClient
private lateinit var addressBook: TestAddressBook
@BeforeClass
@JvmStatic
fun connect() {
provider = testContext.contentResolver.acquireContentProviderClient(ContactsContract.AUTHORITY)!!
Assert.assertNotNull(provider)
addressBook = TestAddressBook(testAccount, provider)
}
@BeforeClass
@JvmStatic
fun disconnect() {
@Suppress("DEPRECATION")
provider.release()
}
}
@Test
fun testPhoto_Empty() {
val contact = Contact()
PhotoHandler(null).handle(ContentValues().apply {
putNull(Photo.PHOTO)
}, contact)
assertNull(contact.photo)
}
@Test
fun testPhoto_Blob() {
val blob = ByteArray(1024) { Random.nextInt().toByte() }
val contact = Contact()
PhotoHandler(null).handle(ContentValues().apply {
put(Photo.PHOTO, blob)
}, contact)
assertEquals(blob, contact.photo)
}
@Test
fun testPhoto_FileId() {
val contact = Contact().apply {
displayName = "Contact with photo"
photo = IOUtils.resourceToByteArray("/large.jpg")
}
val androidContact = AndroidContact(addressBook, contact, null, null)
val rawContactId = ContentUris.parseId(androidContact.add())
val dataUri = ContentUris.withAppendedId(RawContacts.CONTENT_URI, rawContactId).buildUpon()
.appendPath(RawContacts.Data.CONTENT_DIRECTORY)
.build()
val thumbnail = provider.query(dataUri, arrayOf(Photo.PHOTO_FILE_ID, Photo.PHOTO),
"${RawContacts.Data.MIMETYPE}=?", arrayOf(Photo.CONTENT_ITEM_TYPE),
null
)!!.use { cursor ->
assertTrue(cursor.moveToNext())
val fileId = cursor.getLong(0)
assertNotNull(fileId)
val blob = cursor.getBlob(1)
assertNotNull(blob)
blob!!
}
val contact2 = addressBook.findContactById(rawContactId)
// now PhotoHandler handles the PHOTO_FILE_ID
val photo2 = contact2.getContact().photo
assertNotNull(photo2)
// make sure PhotoHandler didn't just return the thumbnail blob
assertNotEquals(thumbnail, photo2)
}
}
|