An amazing project that generates micro reports from tournament results
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

834 lines
32 KiB

////////////////////////////////////////////////////////////////////////////
//
// Copyright 2015 Realm Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
////////////////////////////////////////////////////////////////////////////
import XCTest
#if DEBUG
@testable import RealmSwift
#else
import RealmSwift
#endif
import Foundation
class RealmTests: TestCase {
enum TestError: Error {
case intentional
}
func testFileURL() {
XCTAssertEqual(try! Realm(fileURL: testRealmURL()).configuration.fileURL,
testRealmURL())
}
func testReadOnly() {
autoreleasepool {
XCTAssertEqual(try! Realm().configuration.readOnly, false)
try! Realm().write {
try! Realm().create(SwiftIntObject.self, value: [100])
}
}
let config = Realm.Configuration(fileURL: defaultRealmURL(), readOnly: true)
let readOnlyRealm = try! Realm(configuration: config)
XCTAssertEqual(true, readOnlyRealm.configuration.readOnly)
XCTAssertEqual(1, readOnlyRealm.objects(SwiftIntObject.self).count)
assertThrows(try! Realm(), "Realm has different readOnly settings")
}
func testOpeningInvalidPathThrows() {
assertFails(.fileAccess) {
try Realm(configuration: Realm.Configuration(fileURL: URL(fileURLWithPath: "/dev/null/foo")))
}
}
func testReadOnlyFile() {
autoreleasepool {
let realm = try! Realm(fileURL: testRealmURL())
try! realm.write {
realm.create(SwiftStringObject.self, value: ["a"])
}
}
let fileManager = FileManager.default
try! fileManager.setAttributes([ FileAttributeKey.immutable: true ], ofItemAtPath: testRealmURL().path)
// Should not be able to open read-write
assertFails(.fileAccess) {
try Realm(fileURL: testRealmURL())
}
assertSucceeds {
let realm = try Realm(configuration:
Realm.Configuration(fileURL: testRealmURL(), readOnly: true))
XCTAssertEqual(1, realm.objects(SwiftStringObject.self).count)
}
try! fileManager.setAttributes([ FileAttributeKey.immutable: false ], ofItemAtPath: testRealmURL().path)
}
func testReadOnlyRealmMustExist() {
assertFails(.fileNotFound) {
try Realm(configuration:
Realm.Configuration(fileURL: defaultRealmURL(), readOnly: true))
}
}
func testFilePermissionDenied() {
autoreleasepool {
_ = try! Realm(fileURL: testRealmURL())
}
// Make Realm at test path temporarily unreadable
let fileManager = FileManager.default
let permissions = try! fileManager
.attributesOfItem(atPath: testRealmURL().path)[FileAttributeKey.posixPermissions] as! NSNumber
try! fileManager.setAttributes([ FileAttributeKey.posixPermissions: 0000 ],
ofItemAtPath: testRealmURL().path)
assertFails(.filePermissionDenied) {
try Realm(fileURL: testRealmURL())
}
try! fileManager.setAttributes([FileAttributeKey.posixPermissions: permissions], ofItemAtPath: testRealmURL().path)
}
#if DEBUG
func testFileFormatUpgradeRequiredButDisabled() {
var config = Realm.Configuration()
var bundledRealmPath = NSBundle(forClass: RealmTests.self).pathForResource("fileformat-pre-null.realm",
ofType: nil)!
try! NSFileManager.defaultManager.copyItemAtPath(bundledRealmPath, toPath: config.path)
config.disableFormatUpgrade = true
assertFails(Error.FileFormatUpgradeRequired) {
try Realm(configuration: config)
}
}
#endif
func testSchema() {
let schema = try! Realm().schema
XCTAssert(schema as AnyObject is Schema)
XCTAssertEqual(1, schema.objectSchema.filter({ $0.className == "SwiftStringObject" }).count)
}
func testIsEmpty() {
let realm = try! Realm()
XCTAssert(realm.isEmpty, "Realm should be empty on creation.")
realm.beginWrite()
realm.create(SwiftStringObject.self, value: ["a"])
XCTAssertFalse(realm.isEmpty, "Realm should not be empty within a write transaction after adding an object.")
realm.cancelWrite()
XCTAssertTrue(realm.isEmpty, "Realm should be empty after canceling a write transaction that added an object.")
realm.beginWrite()
realm.create(SwiftStringObject.self, value: ["a"])
try! realm.commitWrite()
XCTAssertFalse(realm.isEmpty,
"Realm should not be empty after committing a write transaction that added an object.")
}
func testInit() {
XCTAssertEqual(try! Realm(fileURL: testRealmURL()).configuration.fileURL,
testRealmURL())
}
func testInitFailable() {
autoreleasepool {
_ = try! Realm()
}
FileManager.default.createFile(atPath: defaultRealmURL().path,
contents: "a".data(using: String.Encoding.utf8, allowLossyConversion: false),
attributes: nil)
assertFails(.fileAccess) {
_ = try Realm()
XCTFail("Realm creation should have failed")
}
}
func testInitInMemory() {
autoreleasepool {
let realm = inMemoryRealm("identifier")
try! realm.write {
realm.create(SwiftIntObject.self, value: [1])
return
}
}
let realm = inMemoryRealm("identifier")
XCTAssertEqual(realm.objects(SwiftIntObject.self).count, 0)
try! realm.write {
realm.create(SwiftIntObject.self, value: [1])
XCTAssertEqual(realm.objects(SwiftIntObject.self).count, 1)
inMemoryRealm("identifier").create(SwiftIntObject.self, value: [1])
XCTAssertEqual(realm.objects(SwiftIntObject.self).count, 2)
}
let realm2 = inMemoryRealm("identifier2")
XCTAssertEqual(realm2.objects(SwiftIntObject.self).count, 0)
}
func testInitCustomClassList() {
let configuration = Realm.Configuration(fileURL: Realm.Configuration.defaultConfiguration.fileURL,
objectTypes: [SwiftStringObject.self])
XCTAssert(configuration.objectTypes! is [SwiftStringObject.Type])
let realm = try! Realm(configuration: configuration)
XCTAssertEqual(["SwiftStringObject"], realm.schema.objectSchema.map { $0.className })
}
func testWrite() {
try! Realm().write {
self.assertThrows(try! Realm().beginWrite())
self.assertThrows(try! Realm().write { })
try! Realm().create(SwiftStringObject.self, value: ["1"])
XCTAssertEqual(try! Realm().objects(SwiftStringObject.self).count, 1)
}
XCTAssertEqual(try! Realm().objects(SwiftStringObject.self).count, 1)
}
func testDynamicWrite() {
try! Realm().write {
self.assertThrows(try! Realm().beginWrite())
self.assertThrows(try! Realm().write { })
try! Realm().dynamicCreate("SwiftStringObject", value: ["1"])
XCTAssertEqual(try! Realm().objects(SwiftStringObject.self).count, 1)
}
XCTAssertEqual(try! Realm().objects(SwiftStringObject.self).count, 1)
}
func testDynamicWriteSubscripting() {
try! Realm().beginWrite()
let object = try! Realm().dynamicCreate("SwiftStringObject", value: ["1"])
try! Realm().commitWrite()
XCTAssertNotNil(object, "Dynamic Object Creation Failed")
let stringVal = object["stringCol"] as! String
XCTAssertEqual(stringVal, "1", "Object Subscripting Failed")
}
func testBeginWrite() {
try! Realm().beginWrite()
assertThrows(try! Realm().beginWrite())
try! Realm().cancelWrite()
try! Realm().beginWrite()
try! Realm().create(SwiftStringObject.self, value: ["1"])
XCTAssertEqual(try! Realm().objects(SwiftStringObject.self).count, 1)
}
func testCommitWrite() {
try! Realm().beginWrite()
try! Realm().create(SwiftStringObject.self, value: ["1"])
try! Realm().commitWrite()
XCTAssertEqual(try! Realm().objects(SwiftStringObject.self).count, 1)
try! Realm().beginWrite()
}
func testCancelWrite() {
assertThrows(try! Realm().cancelWrite())
try! Realm().beginWrite()
try! Realm().create(SwiftStringObject.self, value: ["1"])
try! Realm().cancelWrite()
XCTAssertEqual(try! Realm().objects(SwiftStringObject.self).count, 0)
try! Realm().write {
self.assertThrows(self.realmWithTestPath().cancelWrite())
let object = try! Realm().create(SwiftStringObject.self)
try! Realm().cancelWrite()
XCTAssertTrue(object.isInvalidated)
XCTAssertEqual(try! Realm().objects(SwiftStringObject.self).count, 0)
}
XCTAssertEqual(try! Realm().objects(SwiftStringObject.self).count, 0)
}
func testThrowsWrite() {
assertFails(TestError.intentional) {
try Realm().write {
throw TestError.intentional
}
}
assertFails(TestError.intentional) {
try Realm().write {
try! Realm().create(SwiftStringObject.self, value: ["1"])
throw TestError.intentional
}
}
}
func testInWriteTransaction() {
let realm = try! Realm()
XCTAssertFalse(realm.isInWriteTransaction)
realm.beginWrite()
XCTAssertTrue(realm.isInWriteTransaction)
realm.cancelWrite()
try! realm.write {
XCTAssertTrue(realm.isInWriteTransaction)
realm.cancelWrite()
XCTAssertFalse(realm.isInWriteTransaction)
}
realm.beginWrite()
realm.invalidate()
XCTAssertFalse(realm.isInWriteTransaction)
}
func testAddSingleObject() {
let realm = try! Realm()
assertThrows(_ = realm.add(SwiftObject()))
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
var defaultRealmObject: SwiftObject!
try! realm.write {
defaultRealmObject = SwiftObject()
realm.add(defaultRealmObject)
XCTAssertEqual(1, realm.objects(SwiftObject.self).count)
realm.add(defaultRealmObject)
XCTAssertEqual(1, realm.objects(SwiftObject.self).count)
}
XCTAssertEqual(1, realm.objects(SwiftObject.self).count)
let testRealm = realmWithTestPath()
try! testRealm.write {
self.assertThrows(_ = testRealm.add(defaultRealmObject))
}
}
func testAddWithUpdateSingleObject() {
let realm = try! Realm()
XCTAssertEqual(0, realm.objects(SwiftPrimaryStringObject.self).count)
var defaultRealmObject: SwiftPrimaryStringObject!
try! realm.write {
defaultRealmObject = SwiftPrimaryStringObject()
realm.add(defaultRealmObject, update: .all)
XCTAssertEqual(1, realm.objects(SwiftPrimaryStringObject.self).count)
realm.add(SwiftPrimaryStringObject(), update: .all)
XCTAssertEqual(1, realm.objects(SwiftPrimaryStringObject.self).count)
}
XCTAssertEqual(1, realm.objects(SwiftPrimaryStringObject.self).count)
let testRealm = realmWithTestPath()
try! testRealm.write {
self.assertThrows(_ = testRealm.add(defaultRealmObject, update: .all))
}
}
func testAddMultipleObjects() {
let realm = try! Realm()
assertThrows(_ = realm.add([SwiftObject(), SwiftObject()]))
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
try! realm.write {
let objs = [SwiftObject(), SwiftObject()]
realm.add(objs)
XCTAssertEqual(2, realm.objects(SwiftObject.self).count)
}
XCTAssertEqual(2, realm.objects(SwiftObject.self).count)
let testRealm = realmWithTestPath()
try! testRealm.write {
self.assertThrows(_ = testRealm.add(realm.objects(SwiftObject.self)))
}
}
func testAddWithUpdateMultipleObjects() {
let realm = try! Realm()
XCTAssertEqual(0, realm.objects(SwiftPrimaryStringObject.self).count)
try! realm.write {
let objs = [SwiftPrimaryStringObject(), SwiftPrimaryStringObject()]
realm.add(objs, update: .all)
XCTAssertEqual(1, realm.objects(SwiftPrimaryStringObject.self).count)
}
XCTAssertEqual(1, realm.objects(SwiftPrimaryStringObject.self).count)
let testRealm = realmWithTestPath()
try! testRealm.write {
self.assertThrows(_ = testRealm.add(realm.objects(SwiftPrimaryStringObject.self), update: .all))
}
}
// create() tests are in ObjectCreationTests.swift
func testDeleteSingleObject() {
let realm = try! Realm()
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
assertThrows(_ = realm.delete(SwiftObject()))
var defaultRealmObject: SwiftObject!
try! realm.write {
defaultRealmObject = SwiftObject()
self.assertThrows(_ = realm.delete(defaultRealmObject))
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
realm.add(defaultRealmObject)
XCTAssertEqual(1, realm.objects(SwiftObject.self).count)
realm.delete(defaultRealmObject)
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
}
assertThrows(_ = realm.delete(defaultRealmObject))
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
let testRealm = realmWithTestPath()
assertThrows(_ = testRealm.delete(defaultRealmObject))
try! testRealm.write {
self.assertThrows(_ = testRealm.delete(defaultRealmObject))
}
}
func testDeleteSequenceOfObjects() {
let realm = try! Realm()
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
var objs: [SwiftObject]!
try! realm.write {
objs = [SwiftObject(), SwiftObject()]
realm.add(objs)
XCTAssertEqual(2, realm.objects(SwiftObject.self).count)
realm.delete(objs)
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
}
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
let testRealm = realmWithTestPath()
assertThrows(_ = testRealm.delete(objs))
try! testRealm.write {
self.assertThrows(_ = testRealm.delete(objs))
}
}
func testDeleteListOfObjects() {
let realm = try! Realm()
XCTAssertEqual(0, realm.objects(SwiftCompanyObject.self).count)
try! realm.write {
let obj = SwiftCompanyObject()
obj.employees.append(SwiftEmployeeObject())
realm.add(obj)
XCTAssertEqual(1, realm.objects(SwiftEmployeeObject.self).count)
realm.delete(obj.employees)
XCTAssertEqual(0, obj.employees.count)
XCTAssertEqual(0, realm.objects(SwiftEmployeeObject.self).count)
}
XCTAssertEqual(0, realm.objects(SwiftEmployeeObject.self).count)
}
func testDeleteResults() {
let realm = try! Realm(fileURL: testRealmURL())
XCTAssertEqual(0, realm.objects(SwiftCompanyObject.self).count)
try! realm.write {
realm.add(SwiftIntObject(value: [1]))
realm.add(SwiftIntObject(value: [1]))
realm.add(SwiftIntObject(value: [2]))
XCTAssertEqual(3, realm.objects(SwiftIntObject.self).count)
realm.delete(realm.objects(SwiftIntObject.self).filter("intCol = 1"))
XCTAssertEqual(1, realm.objects(SwiftIntObject.self).count)
}
XCTAssertEqual(1, realm.objects(SwiftIntObject.self).count)
}
func testDeleteAll() {
let realm = try! Realm()
try! realm.write {
realm.add(SwiftObject())
XCTAssertEqual(1, realm.objects(SwiftObject.self).count)
realm.deleteAll()
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
}
XCTAssertEqual(0, realm.objects(SwiftObject.self).count)
}
func testObjects() {
try! Realm().write {
try! Realm().create(SwiftIntObject.self, value: [100])
try! Realm().create(SwiftIntObject.self, value: [200])
try! Realm().create(SwiftIntObject.self, value: [300])
}
XCTAssertEqual(0, try! Realm().objects(SwiftStringObject.self).count)
XCTAssertEqual(3, try! Realm().objects(SwiftIntObject.self).count)
assertThrows(try! Realm().objects(Object.self))
}
func testDynamicObjects() {
try! Realm().write {
try! Realm().create(SwiftIntObject.self, value: [100])
try! Realm().create(SwiftIntObject.self, value: [200])
try! Realm().create(SwiftIntObject.self, value: [300])
}
XCTAssertEqual(0, try! Realm().dynamicObjects("SwiftStringObject").count)
XCTAssertEqual(3, try! Realm().dynamicObjects("SwiftIntObject").count)
assertThrows(try! Realm().dynamicObjects("Object"))
}
func testDynamicObjectProperties() {
try! Realm().write {
try! Realm().create(SwiftObject.self)
}
let object = try! Realm().dynamicObjects("SwiftObject")[0]
let dictionary = SwiftObject.defaultValues()
XCTAssertEqual(object["boolCol"] as? NSNumber, dictionary["boolCol"] as! NSNumber?)
XCTAssertEqual(object["intCol"] as? NSNumber, dictionary["intCol"] as! NSNumber?)
XCTAssertEqual(object["floatCol"] as! Float, dictionary["floatCol"] as! Float, accuracy: 0.001)
XCTAssertEqual(object["doubleCol"] as? NSNumber, dictionary["doubleCol"] as! NSNumber?)
XCTAssertEqual(object["stringCol"] as! String?, dictionary["stringCol"] as! String?)
XCTAssertEqual(object["binaryCol"] as! NSData?, dictionary["binaryCol"] as! NSData?)
XCTAssertEqual(object["dateCol"] as! Date?, dictionary["dateCol"] as! Date?)
XCTAssertEqual((object["objectCol"] as? SwiftBoolObject)?.boolCol, false)
}
func testDynamicObjectOptionalProperties() {
try! Realm().write {
try! Realm().create(SwiftOptionalDefaultValuesObject.self)
}
let object = try! Realm().dynamicObjects("SwiftOptionalDefaultValuesObject")[0]
let dictionary = SwiftOptionalDefaultValuesObject.defaultValues()
XCTAssertEqual(object["optIntCol"] as? NSNumber, dictionary["optIntCol"] as! NSNumber?)
XCTAssertEqual(object["optInt8Col"] as? NSNumber, dictionary["optInt8Col"] as! NSNumber?)
XCTAssertEqual(object["optInt16Col"] as? NSNumber, dictionary["optInt16Col"] as! NSNumber?)
XCTAssertEqual(object["optInt32Col"] as? NSNumber, dictionary["optInt32Col"] as! NSNumber?)
XCTAssertEqual(object["optInt64Col"] as? NSNumber, dictionary["optInt64Col"] as! NSNumber?)
XCTAssertEqual(object["optFloatCol"] as? NSNumber, dictionary["optFloatCol"] as! NSNumber?)
XCTAssertEqual(object["optDoubleCol"] as? NSNumber, dictionary["optDoubleCol"] as! NSNumber?)
XCTAssertEqual(object["optStringCol"] as! String?, dictionary["optStringCol"] as! String?)
XCTAssertEqual(object["optNSStringCol"] as! String?, dictionary["optNSStringCol"] as! String?)
XCTAssertEqual(object["optBinaryCol"] as! NSData?, dictionary["optBinaryCol"] as! NSData?)
XCTAssertEqual(object["optDateCol"] as! Date?, dictionary["optDateCol"] as! Date?)
XCTAssertEqual((object["optObjectCol"] as? SwiftBoolObject)?.boolCol, true)
}
func testIterateDynamicObjects() {
try! Realm().write {
for _ in 1..<3 {
try! Realm().create(SwiftObject.self)
}
}
let objects = try! Realm().dynamicObjects("SwiftObject")
let dictionary = SwiftObject.defaultValues()
for object in objects {
XCTAssertEqual(object["boolCol"] as? NSNumber, dictionary["boolCol"] as! NSNumber?)
XCTAssertEqual(object["intCol"] as? NSNumber, dictionary["intCol"] as! NSNumber?)
XCTAssertEqual(object["floatCol"] as? NSNumber, dictionary["floatCol"] as! NSNumber?)
XCTAssertEqual(object["doubleCol"] as? NSNumber, dictionary["doubleCol"] as! NSNumber?)
XCTAssertEqual(object["stringCol"] as! String?, dictionary["stringCol"] as! String?)
XCTAssertEqual(object["binaryCol"] as! NSData?, dictionary["binaryCol"] as! NSData?)
XCTAssertEqual(object["dateCol"] as! Date?, dictionary["dateCol"] as! Date?)
XCTAssertEqual((object["objectCol"] as? SwiftBoolObject)?.boolCol, false)
}
}
func testDynamicObjectListProperties() {
try! Realm().write {
try! Realm().create(SwiftArrayPropertyObject.self, value: ["string", [["array"]], [[2]]])
}
let object = try! Realm().dynamicObjects("SwiftArrayPropertyObject")[0]
XCTAssertEqual(object["name"] as? String, "string")
let array = object["array"] as! List<DynamicObject>
XCTAssertEqual(array.first!["stringCol"] as? String, "array")
XCTAssertEqual(array.last!["stringCol"] as? String, "array")
for object in array {
XCTAssertEqual(object["stringCol"] as? String, "array")
}
let intArray = object["intArray"] as! List<DynamicObject>
XCTAssertEqual(intArray[0]["intCol"] as? Int, 2)
XCTAssertEqual(intArray.first!["intCol"] as? Int, 2)
XCTAssertEqual(intArray.last!["intCol"] as? Int, 2)
for object in intArray {
XCTAssertEqual(object["intCol"] as? Int, 2)
}
}
func testIntPrimaryKey() {
func testIntPrimaryKey<O: Object>(for type: O.Type)
where O: SwiftPrimaryKeyObjectType, O.PrimaryKey: ExpressibleByIntegerLiteral {
let realm = try! Realm()
try! realm.write {
realm.create(type, value: ["a", 1])
realm.create(type, value: ["b", 2])
}
let object = realm.object(ofType: type, forPrimaryKey: 1 as O.PrimaryKey)
XCTAssertNotNil(object)
let missingObject = realm.object(ofType: type, forPrimaryKey: 0 as O.PrimaryKey)
XCTAssertNil(missingObject)
}
testIntPrimaryKey(for: SwiftPrimaryIntObject.self)
testIntPrimaryKey(for: SwiftPrimaryInt8Object.self)
testIntPrimaryKey(for: SwiftPrimaryInt16Object.self)
testIntPrimaryKey(for: SwiftPrimaryInt32Object.self)
testIntPrimaryKey(for: SwiftPrimaryInt64Object.self)
}
func testOptionalIntPrimaryKey() {
func testOptionalIntPrimaryKey<O: Object, Wrapped>(for type: O.Type, _ wrapped: Wrapped.Type)
where Wrapped: ExpressibleByIntegerLiteral {
let realm = try! Realm()
try! realm.write {
realm.create(type, value: ["a", NSNull()])
realm.create(type, value: ["b", 2])
}
let object1a = realm.object(ofType: type, forPrimaryKey: NSNull())
XCTAssertNotNil(object1a)
let object1b = realm.object(ofType: type, forPrimaryKey: nil as Wrapped?)
XCTAssertNotNil(object1b)
let object2 = realm.object(ofType: type, forPrimaryKey: 2 as Wrapped)
XCTAssertNotNil(object2)
let missingObject = realm.object(ofType: type, forPrimaryKey: 0 as Wrapped)
XCTAssertNil(missingObject)
}
testOptionalIntPrimaryKey(for: SwiftPrimaryOptionalIntObject.self, Int.self)
testOptionalIntPrimaryKey(for: SwiftPrimaryOptionalInt8Object.self, Int8.self)
testOptionalIntPrimaryKey(for: SwiftPrimaryOptionalInt16Object.self, Int16.self)
testOptionalIntPrimaryKey(for: SwiftPrimaryOptionalInt32Object.self, Int32.self)
testOptionalIntPrimaryKey(for: SwiftPrimaryOptionalInt64Object.self, Int64.self)
}
func testStringPrimaryKey() {
let realm = try! Realm()
try! realm.write {
realm.create(SwiftPrimaryStringObject.self, value: ["a", 1])
realm.create(SwiftPrimaryStringObject.self, value: ["b", 2])
}
// When this is directly inside the XCTAssertNotNil, it doesn't work
let object = realm.object(ofType: SwiftPrimaryStringObject.self, forPrimaryKey: "a")
XCTAssertNotNil(object)
// When this is directly inside the XCTAssertNil, it fails for some reason
let missingObject = realm.object(ofType: SwiftPrimaryStringObject.self, forPrimaryKey: "z")
XCTAssertNil(missingObject)
}
func testOptionalStringPrimaryKey() {
let realm = try! Realm()
try! realm.write {
realm.create(SwiftPrimaryStringObject.self, value: ["a", 1])
realm.create(SwiftPrimaryStringObject.self, value: ["b", 2])
realm.create(SwiftPrimaryOptionalStringObject.self, value: [NSNull(), 1])
realm.create(SwiftPrimaryOptionalStringObject.self, value: ["b", 2])
}
let object1 = realm.object(ofType: SwiftPrimaryOptionalStringObject.self, forPrimaryKey: NSNull())
XCTAssertNotNil(object1)
let object2 = realm.object(ofType: SwiftPrimaryOptionalStringObject.self, forPrimaryKey: "b")
XCTAssertNotNil(object2)
let missingObject = realm.object(ofType: SwiftPrimaryOptionalStringObject.self, forPrimaryKey: "z")
XCTAssertNil(missingObject)
}
func testDynamicObjectForPrimaryKey() {
let realm = try! Realm()
try! realm.write {
realm.create(SwiftPrimaryStringObject.self, value: ["a", 1])
realm.create(SwiftPrimaryStringObject.self, value: ["b", 2])
}
XCTAssertNotNil(realm.dynamicObject(ofType: "SwiftPrimaryStringObject", forPrimaryKey: "a"))
XCTAssertNil(realm.dynamicObject(ofType: "SwiftPrimaryStringObject", forPrimaryKey: "z"))
}
func testDynamicObjectForPrimaryKeySubscripting() {
let realm = try! Realm()
try! realm.write {
realm.create(SwiftPrimaryStringObject.self, value: ["a", 1])
}
let object = realm.dynamicObject(ofType: "SwiftPrimaryStringObject", forPrimaryKey: "a")
let stringVal = object!["stringCol"] as! String
XCTAssertEqual(stringVal, "a", "Object Subscripting Failed!")
}
func testObserve() {
let realm = try! Realm()
var notificationCalled = false
let token = realm.observe { _, realm in
XCTAssertEqual(realm.configuration.fileURL, self.defaultRealmURL())
notificationCalled = true
}
XCTAssertFalse(notificationCalled)
try! realm.write {}
XCTAssertTrue(notificationCalled)
token.invalidate()
}
func testRemoveNotification() {
let realm = try! Realm()
var notificationCalled = false
let token = realm.observe { (_, realm) -> Void in
XCTAssertEqual(realm.configuration.fileURL, self.defaultRealmURL())
notificationCalled = true
}
token.invalidate()
try! realm.write {}
XCTAssertFalse(notificationCalled)
}
func testAutorefresh() {
let realm = try! Realm()
XCTAssertTrue(realm.autorefresh, "Autorefresh should default to true")
realm.autorefresh = false
XCTAssertFalse(realm.autorefresh)
realm.autorefresh = true
XCTAssertTrue(realm.autorefresh)
// test that autoreresh is applied
// we have two notifications, one for opening the realm, and a second when performing our transaction
let notificationFired = expectation(description: "notification fired")
let token = realm.observe { _, realm in
XCTAssertNotNil(realm, "Realm should not be nil")
notificationFired.fulfill()
}
dispatchSyncNewThread {
let realm = try! Realm()
try! realm.write {
realm.create(SwiftStringObject.self, value: ["string"])
}
}
waitForExpectations(timeout: 1, handler: nil)
token.invalidate()
// get object
let results = realm.objects(SwiftStringObject.self)
XCTAssertEqual(results.count, Int(1), "There should be 1 object of type StringObject")
XCTAssertEqual(results[0].stringCol, "string", "Value of first column should be 'string'")
}
func testRefresh() {
let realm = try! Realm()
realm.autorefresh = false
// test that autoreresh is not applied
// we have two notifications, one for opening the realm, and a second when performing our transaction
let notificationFired = expectation(description: "notification fired")
let token = realm.observe { _, realm in
XCTAssertNotNil(realm, "Realm should not be nil")
notificationFired.fulfill()
}
let results = realm.objects(SwiftStringObject.self)
XCTAssertEqual(results.count, Int(0), "There should be 1 object of type StringObject")
dispatchSyncNewThread {
try! Realm().write {
try! Realm().create(SwiftStringObject.self, value: ["string"])
return
}
}
waitForExpectations(timeout: 1, handler: nil)
token.invalidate()
XCTAssertEqual(results.count, Int(0), "There should be 1 object of type StringObject")
// refresh
realm.refresh()
XCTAssertEqual(results.count, Int(1), "There should be 1 object of type StringObject")
XCTAssertEqual(results[0].stringCol, "string", "Value of first column should be 'string'")
}
func testInvalidate() {
let realm = try! Realm()
let object = SwiftObject()
try! realm.write {
realm.add(object)
return
}
realm.invalidate()
XCTAssertEqual(object.isInvalidated, true)
try! realm.write {
realm.add(SwiftObject())
return
}
XCTAssertEqual(realm.objects(SwiftObject.self).count, 2)
XCTAssertEqual(object.isInvalidated, true)
}
func testWriteCopyToPath() {
let realm = try! Realm()
try! realm.write {
realm.add(SwiftObject())
}
let fileURL = defaultRealmURL().deletingLastPathComponent().appendingPathComponent("copy.realm")
do {
try realm.writeCopy(toFile: fileURL)
} catch {
XCTFail("writeCopyToURL failed")
}
autoreleasepool {
let copy = try! Realm(fileURL: fileURL)
XCTAssertEqual(1, copy.objects(SwiftObject.self).count)
}
try! FileManager.default.removeItem(at: fileURL)
}
func testEquals() {
let realm = try! Realm()
XCTAssertTrue(try! realm == Realm())
let testRealm = realmWithTestPath()
XCTAssertFalse(realm == testRealm)
dispatchSyncNewThread {
let otherThreadRealm = try! Realm()
XCTAssertFalse(realm == otherThreadRealm)
}
}
func testCatchSpecificErrors() {
do {
_ = try Realm(configuration: Realm.Configuration(fileURL: URL(fileURLWithPath: "/dev/null/foo")))
XCTFail("Error should be thrown")
} catch Realm.Error.fileAccess {
// Success to catch the error
} catch {
XCTFail("Failed to brigde RLMError to Realm.Error")
}
do {
_ = try Realm(configuration: Realm.Configuration(fileURL: defaultRealmURL(), readOnly: true))
XCTFail("Error should be thrown")
} catch Realm.Error.fileNotFound {
// Success to catch the error
} catch {
XCTFail("Failed to brigde RLMError to Realm.Error")
}
}
}