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 113 114 115 116 117 118 119 120 121
|
//===----------------------------------------------------------------------===//
//
// This source file is part of the SwiftNIO open source project
//
// Copyright (c) 2017-2018 Apple Inc. and the SwiftNIO project authors
// Licensed under Apache License v2.0
//
// See LICENSE.txt for license information
// See CONTRIBUTORS.txt for the list of SwiftNIO project authors
//
// SPDX-License-Identifier: Apache-2.0
//
//===----------------------------------------------------------------------===//
import XCTest
@testable import NIO
class BaseObjectTest: XCTestCase {
func testNIOByteBufferConversion() {
let expected = ByteBufferAllocator().buffer(capacity: 1024)
let asAny = NIOAny(expected)
XCTAssertEqual(expected, asAny.forceAs(type: ByteBuffer.self))
XCTAssertEqual(expected, asAny.forceAsByteBuffer())
if let actual = asAny.tryAs(type: ByteBuffer.self) {
XCTAssertEqual(expected, actual)
} else {
XCTFail("tryAs didn't work")
}
if let actual = asAny.tryAsByteBuffer() {
XCTAssertEqual(expected, actual)
} else {
XCTFail("tryAs didn't work")
}
}
func testNIOIODataConversion() {
let expected = IOData.byteBuffer(ByteBufferAllocator().buffer(capacity: 1024))
let asAny = NIOAny(expected)
XCTAssertEqual(expected, asAny.forceAs(type: IOData.self))
XCTAssertEqual(expected, asAny.forceAsIOData())
if let actual = asAny.tryAs(type: IOData.self) {
XCTAssertEqual(expected, actual)
} else {
XCTFail("tryAs didn't work")
}
if let actual = asAny.tryAsIOData() {
XCTAssertEqual(expected, actual)
} else {
XCTFail("tryAs didn't work")
}
}
func testNIOFileRegionConversion() {
let handle = NIOFileHandle(descriptor: -1)
let expected = FileRegion(fileHandle: handle, readerIndex: 1, endIndex: 2)
defer {
// fake descriptor, so shouldn't be closed.
XCTAssertNoThrow(try handle.takeDescriptorOwnership())
}
let asAny = NIOAny(expected)
XCTAssert(expected == asAny.forceAs(type: FileRegion.self))
XCTAssert(expected == asAny.forceAsFileRegion())
if let actual = asAny.tryAs(type: FileRegion.self) {
XCTAssert(expected == actual)
} else {
XCTFail("tryAs didn't work")
}
if let actual = asAny.tryAsFileRegion() {
XCTAssert(expected == actual)
} else {
XCTFail("tryAs didn't work")
}
}
func testBadConversions() {
let handle = NIOFileHandle(descriptor: -1)
let bb = ByteBufferAllocator().buffer(capacity: 1024)
let fr = FileRegion(fileHandle: handle, readerIndex: 1, endIndex: 2)
defer {
// fake descriptor, so shouldn't be closed.
XCTAssertNoThrow(try handle.takeDescriptorOwnership())
}
let id = IOData.byteBuffer(bb)
XCTAssertNil(NIOAny(bb).tryAsFileRegion())
XCTAssertNil(NIOAny(fr).tryAsByteBuffer())
XCTAssertNil(NIOAny(id).tryAsFileRegion())
}
func testByteBufferFromIOData() {
let expected = ByteBufferAllocator().buffer(capacity: 1024)
let wrapped = IOData.byteBuffer(expected)
XCTAssertEqual(expected, NIOAny(wrapped).tryAsByteBuffer())
}
func testFileRegionFromIOData() {
let handle = NIOFileHandle(descriptor: -1)
let expected = FileRegion(fileHandle: handle, readerIndex: 1, endIndex: 2)
defer {
// fake descriptor, so shouldn't be closed.
XCTAssertNoThrow(try handle.takeDescriptorOwnership())
}
let wrapped = IOData.fileRegion(expected)
XCTAssert(expected == NIOAny(wrapped).tryAsFileRegion())
}
func testIODataEquals() {
let handle = NIOFileHandle(descriptor: -1)
var bb1 = ByteBufferAllocator().buffer(capacity: 1024)
let bb2 = ByteBufferAllocator().buffer(capacity: 1024)
bb1.writeString("hello")
let fr = FileRegion(fileHandle: handle, readerIndex: 1, endIndex: 2)
defer {
// fake descriptor, so shouldn't be closed.
XCTAssertNoThrow(try handle.takeDescriptorOwnership())
}
XCTAssertEqual(IOData.byteBuffer(bb1), IOData.byteBuffer(bb1))
XCTAssertNotEqual(IOData.byteBuffer(bb1), IOData.byteBuffer(bb2))
XCTAssertNotEqual(IOData.byteBuffer(bb1), IOData.fileRegion(fr))
}
}
|