Browse Source

Changes for unit tests.

pull/113/head
Abhishek Banthia 3 years ago
parent
commit
535498c116
  1. 8
      Clocker/AppDelegate.swift
  2. 82
      Clocker/ClockerUnitTests/AppDelegateTests.swift
  3. 13
      Clocker/Preferences/Menu Bar/StatusItemHandler.swift

8
Clocker/AppDelegate.swift

@ -243,15 +243,13 @@ open class AppDelegate: NSObject, NSApplicationDelegate {
let displayMode = UserDefaults.standard.integer(forKey: CLShowAppInForeground) let displayMode = UserDefaults.standard.integer(forKey: CLShowAppInForeground)
if displayMode == 1 { if displayMode == 1 {
floatingWindow.showWindow(nil) // No need to call NSApp.activate here since `showFloatingWindow` takes care of this
floatingWindow.updateTableContent() showFloatingWindow()
floatingWindow.startWindowTimer()
} else { } else {
panelController.showWindow(nil) panelController.showWindow(nil)
panelController.setActivePanel(newValue: !panelController.hasActivePanelGetter()) panelController.setActivePanel(newValue: !panelController.hasActivePanelGetter())
NSApp.activate(ignoringOtherApps: true)
} }
NSApp.activate(ignoringOtherApps: true)
} }
open func setupFloatingWindow(_ hide: Bool) { open func setupFloatingWindow(_ hide: Bool) {

82
Clocker/ClockerUnitTests/AppDelegateTests.swift

@ -1,6 +1,7 @@
// Copyright © 2015 Abhishek Banthia // Copyright © 2015 Abhishek Banthia
import XCTest import XCTest
import CoreModelKit
@testable import Clocker @testable import Clocker
@ -43,7 +44,7 @@ class AppDelegateTests: XCTestCase {
func testFloatingWindow() { func testFloatingWindow() {
let subject = NSApplication.shared.delegate as? AppDelegate let subject = NSApplication.shared.delegate as? AppDelegate
let previousWindows = NSApplication.shared.windows let previousWindows = NSApplication.shared.windows
XCTAssertEqual(previousWindows.count, 1) // Only the status bar window should be present XCTAssertTrue(previousWindows.count >= 1) // Only the status bar window should be present
subject?.setupFloatingWindow(true) subject?.setupFloatingWindow(true)
@ -69,5 +70,84 @@ class AppDelegateTests: XCTestCase {
XCTAssertNotNil(closedFloatingWindow) XCTAssertNotNil(closedFloatingWindow)
} }
func testActivationPolicy() {
let subject = NSApplication.shared.delegate as? AppDelegate
let previousOption = UserDefaults.standard.integer(forKey: CLAppDisplayOptions)
if previousOption == 0 {
XCTAssertEqual(NSApp.activationPolicy(), .accessory)
} else {
XCTAssertEqual(NSApp.activationPolicy(), .regular)
}
subject?.hideFromDock()
XCTAssertEqual(NSApp.activationPolicy(), .accessory)
}
func testMenubarInvalidationToIcon() {
let subject = NSApplication.shared.delegate as? AppDelegate
subject?.invalidateMenubarTimer(true)
let statusItemHandler = subject?.statusItemForPanel()
XCTAssertNil(statusItemHandler?.statusItem.view)
XCTAssertEqual(statusItemHandler?.statusItem.title, CLEmptyString)
XCTAssertEqual(statusItemHandler?.statusItem.button?.image?.name(), "LightModeIcon")
XCTAssertEqual(statusItemHandler?.statusItem.button?.imagePosition, .imageOnly)
XCTAssertEqual(statusItemHandler?.statusItem.toolTip, "Clocker")
}
func testCompactModeMenubarSetup() {
let subject = NSApplication.shared.delegate as? AppDelegate
let timezone1 = TimezoneData()
timezone1.timezoneID = TimeZone.autoupdatingCurrent.identifier
timezone1.formattedAddress = "MenubarTimezone"
timezone1.isFavourite = 1
// Encode it in UserDefaults
let encodedTimezone = NSKeyedArchiver.archivedData(withRootObject: timezone1)
DataStore.shared().setTimezones([encodedTimezone])
subject?.setupMenubarTimer()
let statusItemHandler = subject?.statusItemForPanel()
XCTAssertNotNil(statusItemHandler?.statusItem.view) // This won't be nil for compact mode
DataStore.shared().setTimezones([])
}
func testStandardModeMenubarSetup() {
UserDefaults.standard.set(1, forKey: CLMenubarCompactMode) // Set the menubar mode to standard
let subject = NSApplication.shared.delegate as? AppDelegate
let statusItemHandler = subject?.statusItemForPanel()
XCTAssertEqual(statusItemHandler?.statusItem.button?.image?.name(), "LightModeIcon")
let timezone1 = TimezoneData()
timezone1.timezoneID = TimeZone.autoupdatingCurrent.identifier
timezone1.formattedAddress = "MenubarTimezone"
timezone1.isFavourite = 1
// Encode it in UserDefaults
let encodedTimezone = NSKeyedArchiver.archivedData(withRootObject: timezone1)
DataStore.shared().setTimezones([encodedTimezone])
subject?.setupMenubarTimer()
XCTAssertNil(statusItemHandler?.statusItem.view) // This won't be nil for compact mode
DataStore.shared().setTimezones([])
UserDefaults.standard.set(0, forKey: CLMenubarCompactMode) // Set the menubar mode back to compact
}
func testTogglingPanel() {
UserDefaults.standard.set(1, forKey: CLShowAppInForeground)
let subject = NSApplication.shared.delegate as? AppDelegate
subject?.ping("MockArgument")
UserDefaults.standard.set(0, forKey: CLShowAppInForeground)
let hasActiveGetter = PanelController.shared().hasActivePanel
subject?.ping("MockArgument")
XCTAssertNotEqual(hasActiveGetter, PanelController.shared().hasActivePanel)
}
} }

13
Clocker/Preferences/Menu Bar/StatusItemHandler.swift

@ -200,17 +200,14 @@ class StatusItemHandler: NSObject {
private func shouldDisplaySecondsInMenubar() -> Bool { private func shouldDisplaySecondsInMenubar() -> Bool {
let syncedTimezones = DataStore.shared().menubarTimezones() ?? [] let syncedTimezones = DataStore.shared().menubarTimezones() ?? []
for timezone in syncedTimezones { let timezonesSupportingSeconds = syncedTimezones.filter { data in
if let timezoneObj = TimezoneData.customObject(from: timezone) { if let timezoneObj = TimezoneData.customObject(from: data) {
let shouldShowSeconds = timezoneObj.shouldShowSeconds(DataStore.shared().timezoneFormat()) return timezoneObj.shouldShowSeconds(DataStore.shared().timezoneFormat())
if shouldShowSeconds {
return true
}
} }
continue return false
} }
return false return timezonesSupportingSeconds.isEmpty
} }
private func calculateFireDate() -> Date? { private func calculateFireDate() -> Date? {

Loading…
Cancel
Save