mirror of
https://github.com/atom/atom.git
synced 2026-02-05 04:05:05 -05:00
145 lines
5.5 KiB
CoffeeScript
145 lines
5.5 KiB
CoffeeScript
RootView = require 'root-view'
|
|
{$$} = require 'space-pen'
|
|
|
|
describe "the `atom` global", ->
|
|
beforeEach ->
|
|
new RootView
|
|
|
|
afterEach ->
|
|
rootView.deactivate()
|
|
|
|
describe ".loadPackage(name)", ->
|
|
[extension, stylesheetPath] = []
|
|
|
|
beforeEach ->
|
|
extension = require "package-with-module"
|
|
stylesheetPath = require.resolve("fixtures/packages/package-with-module/stylesheets/styles.css")
|
|
|
|
afterEach ->
|
|
removeStylesheet(stylesheetPath)
|
|
|
|
it "requires and activates the package's main module if it exists", ->
|
|
spyOn(atom, 'activateAtomPackage').andCallThrough()
|
|
atom.loadPackage("package-with-module")
|
|
expect(atom.activateAtomPackage).toHaveBeenCalled()
|
|
|
|
it "logs warning instead of throwing an exception if a package fails to load", ->
|
|
config.set("core.disabledPackages", [])
|
|
spyOn(console, "warn")
|
|
expect(-> atom.loadPackage("package-that-throws-an-exception")).not.toThrow()
|
|
expect(console.warn).toHaveBeenCalled()
|
|
|
|
describe "keymap loading", ->
|
|
describe "when package.json does not contain a 'keymaps' manifest", ->
|
|
it "loads all the .cson/.json files in the keymaps directory", ->
|
|
element1 = $$ -> @div class: 'test-1'
|
|
element2 = $$ -> @div class: 'test-2'
|
|
element3 = $$ -> @div class: 'test-3'
|
|
|
|
expect(keymap.bindingsForElement(element1)['ctrl-z']).toBeUndefined()
|
|
expect(keymap.bindingsForElement(element2)['ctrl-z']).toBeUndefined()
|
|
expect(keymap.bindingsForElement(element3)['ctrl-z']).toBeUndefined()
|
|
|
|
atom.loadPackage("package-with-module")
|
|
|
|
expect(keymap.bindingsForElement(element1)['ctrl-z']).toBe "test-1"
|
|
expect(keymap.bindingsForElement(element2)['ctrl-z']).toBe "test-2"
|
|
expect(keymap.bindingsForElement(element3)['ctrl-z']).toBeUndefined()
|
|
|
|
describe "when package.json contains a 'keymaps' manifest", ->
|
|
it "loads only the keymaps specified by the manifest, in the specified order", ->
|
|
element1 = $$ -> @div class: 'test-1'
|
|
element3 = $$ -> @div class: 'test-3'
|
|
|
|
expect(keymap.bindingsForElement(element1)['ctrl-z']).toBeUndefined()
|
|
|
|
atom.loadPackage("package-with-keymaps-manifest")
|
|
|
|
expect(keymap.bindingsForElement(element1)['ctrl-z']).toBe 'keymap-1'
|
|
expect(keymap.bindingsForElement(element1)['ctrl-n']).toBe 'keymap-2'
|
|
expect(keymap.bindingsForElement(element3)['ctrl-y']).toBeUndefined()
|
|
|
|
it "loads stylesheets associated with the package", ->
|
|
stylesheetPath = require.resolve("fixtures/packages/package-with-module/stylesheets/styles.css")
|
|
expect(stylesheetElementForId(stylesheetPath).length).toBe 0
|
|
atom.loadPackage("package-with-module")
|
|
expect(stylesheetElementForId(stylesheetPath).length).toBe 1
|
|
|
|
describe ".loadPackages()", ->
|
|
beforeEach ->
|
|
spyOn(syntax, 'addGrammar')
|
|
|
|
it "terminates the worker when all packages have been loaded", ->
|
|
spyOn(Worker.prototype, 'terminate').andCallThrough()
|
|
eventHandler = jasmine.createSpy('eventHandler')
|
|
syntax.on 'grammars-loaded', eventHandler
|
|
disabledPackages = config.get("core.disabledPackages")
|
|
disabledPackages.push('textmate-package.tmbundle')
|
|
disabledPackages.push('package-with-snippets')
|
|
config.set "core.disabledPackages", disabledPackages
|
|
atom.loadPackages()
|
|
|
|
waitsFor "all packages to load", 5000, -> eventHandler.callCount > 0
|
|
|
|
runs ->
|
|
expect(Worker.prototype.terminate).toHaveBeenCalled()
|
|
expect(Worker.prototype.terminate.calls.length).toBe 1
|
|
|
|
describe "package lifecycle", ->
|
|
[pack, packageModule] = []
|
|
|
|
beforeEach ->
|
|
pack =
|
|
name: "package"
|
|
packageMain:
|
|
activate: jasmine.createSpy("activate")
|
|
deactivate: ->
|
|
serialize: -> "it worked"
|
|
|
|
packageModule = pack.packageMain
|
|
|
|
describe ".activateAtomPackage(package)", ->
|
|
it "calls activate on the package", ->
|
|
atom.activateAtomPackage(pack)
|
|
expect(packageModule.activate).toHaveBeenCalledWith(undefined)
|
|
|
|
it "calls activate on the package module with its previous state", ->
|
|
atom.activateAtomPackage(pack)
|
|
packageModule.activate.reset()
|
|
|
|
serializedState = rootView.serialize()
|
|
rootView.deactivate()
|
|
RootView.deserialize(serializedState)
|
|
|
|
atom.activateAtomPackage(pack)
|
|
expect(packageModule.activate).toHaveBeenCalledWith("it worked")
|
|
|
|
describe ".deactivateAtomPackages()", ->
|
|
it "deactivates and removes the package module from the package module map", ->
|
|
atom.activateAtomPackage(pack)
|
|
spyOn(packageModule, "deactivate").andCallThrough()
|
|
atom.deactivateAtomPackages()
|
|
expect(packageModule.deactivate).toHaveBeenCalled()
|
|
expect(rootView.packages.length).toBe 0
|
|
|
|
describe ".serializeAtomPackages()", ->
|
|
it "absorbs exceptions that are thrown by the package module's serialize methods", ->
|
|
spyOn(console, 'error')
|
|
|
|
atom.activateAtomPackage
|
|
name: "bad-egg"
|
|
packageMain:
|
|
activate: ->
|
|
serialize: -> throw new Error("I'm broken")
|
|
|
|
atom.activateAtomPackage
|
|
name: "good-egg"
|
|
packageMain:
|
|
activate: ->
|
|
serialize: -> "I still get called"
|
|
|
|
packageStates = atom.serializeAtomPackages()
|
|
expect(packageStates['good-egg']).toBe "I still get called"
|
|
expect(packageStates['bad-egg']).toBeUndefined()
|
|
expect(console.error).toHaveBeenCalled()
|