material-components_materia.../components/NavigationBar/tests/unit/NavigationBarButtonLayoutTests.swift
Robert Moore 675235ed05
{Tests} Deallocate test objects at the end of tests. (#5397)
Deallocating many of the properties created for each unit test. Since all
XCTestCase instances survive until the end of the test suite, any properties
created for a test will be preserved as well. This frees up around 3.7 MB
(~6%) of memory from the entire test suite, as measured on my desktop.

|Before|After|
|----|----|
|![test-objcs-before](https://user-images.githubusercontent.com/1753199/46813473-c3b9bd00-cd44-11e8-990c-28dff4ab5ad2.png)|![test-objcs-after](https://user-images.githubusercontent.com/1753199/46813481-c7e5da80-cd44-11e8-90e4-2e6d532ebbfb.png)|

See also: https://qualitycoding.org/xctestcase-teardown/

Closes #5395
2018-10-12 08:33:58 -04:00

113 lines
3.5 KiB
Swift

// Copyright 2018-present the Material Components for iOS authors. All Rights Reserved.
//
// 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
import MaterialComponents.MaterialNavigationBar
import MaterialComponents.MaterialButtons
class NavigationBarButtonLayoutTests: XCTestCase {
var navigationBar: MDCNavigationBar!
override func setUp() {
super.setUp()
navigationBar = MDCNavigationBar()
}
override func tearDown() {
navigationBar = nil
super.tearDown()
}
private func recursiveSubviews(of superview: UIView) -> [UIView] {
var subviews = superview.subviews
for subview in superview.subviews {
subviews.append(contentsOf: recursiveSubviews(of: subview))
}
return subviews
}
func testInitialLayoutMatchesSizeThatFitsWidth() {
// Given
navigationBar.leadingBarButtonItems = [
UIBarButtonItem(title: "Text", style: .plain, target: nil, action: nil)
]
navigationBar.trailingBarButtonItems = [
UIBarButtonItem(title: "Text 2", style: .plain, target: nil, action: nil)
]
// Then
for view in recursiveSubviews(of: navigationBar) {
if let button = view as? MDCButton {
let width = button.sizeThatFits(CGSize(width: CGFloat.infinity,
height: CGFloat.infinity)).width
XCTAssertEqual(width, button.bounds.width)
}
}
}
func testChangingTitleUpdatesLayoutToMatchSizeThatFitsWidth() {
// Given
navigationBar.leadingBarButtonItems = [
UIBarButtonItem(title: "Text", style: .plain, target: nil, action: nil)
]
navigationBar.trailingBarButtonItems = [
UIBarButtonItem(title: "Text 2", style: .plain, target: nil, action: nil)
]
// When
navigationBar.leadingBarButtonItems?.forEach {
$0.title = "Longer title"
}
navigationBar.trailingBarButtonItems?.forEach {
$0.title = "Longer title"
}
navigationBar.layoutIfNeeded()
// Then
for view in recursiveSubviews(of: navigationBar) {
if let button = view as? MDCButton {
let width = button.sizeThatFits(CGSize(width: CGFloat.infinity,
height: CGFloat.infinity)).width
XCTAssertEqual(width, button.bounds.width)
}
}
}
func testChangingTitleFontUpdatesLayoutToMatchSizeThatFitsWidth() {
// Given
navigationBar.leadingBarButtonItems = [
UIBarButtonItem(title: "Text", style: .plain, target: nil, action: nil)
]
navigationBar.trailingBarButtonItems = [
UIBarButtonItem(title: "Text 2", style: .plain, target: nil, action: nil)
]
// When
navigationBar.setButtonsTitleFont(UIFont.systemFont(ofSize: 20), for: .normal)
navigationBar.layoutIfNeeded()
// Then
for view in recursiveSubviews(of: navigationBar) {
if let button = view as? MDCButton {
let width = button.sizeThatFits(CGSize(width: CGFloat.infinity,
height: CGFloat.infinity)).width
XCTAssertEqual(width, button.bounds.width)
}
}
}
}