mirror of
https://github.com/pulsar-edit/pulsar.git
synced 2025-01-07 23:59:22 +03:00
d26c19a0ec
It’s not something that will make sense once we add the ability to have multiple directories in a project. This adds a new private method on Project, ::resolvePath, with the original implementation for convenience until we actually implement multi-folder projects.
108 lines
4.7 KiB
CoffeeScript
108 lines
4.7 KiB
CoffeeScript
{$} = require '../src/space-pen-extensions'
|
|
path = require 'path'
|
|
Package = require '../src/package'
|
|
ThemePackage = require '../src/theme-package'
|
|
|
|
describe "Package", ->
|
|
describe "when the package contains incompatible native modules", ->
|
|
beforeEach ->
|
|
spyOn(atom, 'inDevMode').andReturn(false)
|
|
|
|
it "does not activate it", ->
|
|
packagePath = atom.project.getDirectories()[0]?.resolve('packages/package-with-incompatible-native-module')
|
|
pack = new Package(packagePath)
|
|
expect(pack.isCompatible()).toBe false
|
|
expect(pack.incompatibleModules[0].name).toBe 'native-module'
|
|
expect(pack.incompatibleModules[0].path).toBe path.join(packagePath, 'node_modules', 'native-module')
|
|
|
|
it "caches the incompatible native modules in local storage", ->
|
|
packagePath = atom.project.getDirectories()[0]?.resolve('packages/package-with-incompatible-native-module')
|
|
cacheKey = null
|
|
cacheItem = null
|
|
|
|
spyOn(global.localStorage, 'setItem').andCallFake (key, item) ->
|
|
cacheKey = key
|
|
cacheItem = item
|
|
spyOn(global.localStorage, 'getItem').andCallFake (key) ->
|
|
return cacheItem if cacheKey is key
|
|
|
|
expect(new Package(packagePath).isCompatible()).toBe false
|
|
expect(global.localStorage.getItem.callCount).toBe 1
|
|
expect(global.localStorage.setItem.callCount).toBe 1
|
|
|
|
expect(new Package(packagePath).isCompatible()).toBe false
|
|
expect(global.localStorage.getItem.callCount).toBe 2
|
|
expect(global.localStorage.setItem.callCount).toBe 1
|
|
|
|
describe "theme", ->
|
|
theme = null
|
|
|
|
beforeEach ->
|
|
$("#jasmine-content").append $("<atom-text-editor></atom-text-editor>")
|
|
|
|
afterEach ->
|
|
theme.deactivate() if theme?
|
|
|
|
describe "when the theme contains a single style file", ->
|
|
it "loads and applies css", ->
|
|
expect($("atom-text-editor").css("padding-bottom")).not.toBe "1234px"
|
|
themePath = atom.project.getDirectories()[0]?.resolve('packages/theme-with-index-css')
|
|
theme = new ThemePackage(themePath)
|
|
theme.activate()
|
|
expect($("atom-text-editor").css("padding-top")).toBe "1234px"
|
|
|
|
it "parses, loads and applies less", ->
|
|
expect($("atom-text-editor").css("padding-bottom")).not.toBe "1234px"
|
|
themePath = atom.project.getDirectories()[0]?.resolve('packages/theme-with-index-less')
|
|
theme = new ThemePackage(themePath)
|
|
theme.activate()
|
|
expect($("atom-text-editor").css("padding-top")).toBe "4321px"
|
|
|
|
describe "when the theme contains a package.json file", ->
|
|
it "loads and applies stylesheets from package.json in the correct order", ->
|
|
expect($("atom-text-editor").css("padding-top")).not.toBe("101px")
|
|
expect($("atom-text-editor").css("padding-right")).not.toBe("102px")
|
|
expect($("atom-text-editor").css("padding-bottom")).not.toBe("103px")
|
|
|
|
themePath = atom.project.getDirectories()[0]?.resolve('packages/theme-with-package-file')
|
|
theme = new ThemePackage(themePath)
|
|
theme.activate()
|
|
expect($("atom-text-editor").css("padding-top")).toBe("101px")
|
|
expect($("atom-text-editor").css("padding-right")).toBe("102px")
|
|
expect($("atom-text-editor").css("padding-bottom")).toBe("103px")
|
|
|
|
describe "when the theme does not contain a package.json file and is a directory", ->
|
|
it "loads all stylesheet files in the directory", ->
|
|
expect($("atom-text-editor").css("padding-top")).not.toBe "10px"
|
|
expect($("atom-text-editor").css("padding-right")).not.toBe "20px"
|
|
expect($("atom-text-editor").css("padding-bottom")).not.toBe "30px"
|
|
|
|
themePath = atom.project.getDirectories()[0]?.resolve('packages/theme-without-package-file')
|
|
theme = new ThemePackage(themePath)
|
|
theme.activate()
|
|
expect($("atom-text-editor").css("padding-top")).toBe "10px"
|
|
expect($("atom-text-editor").css("padding-right")).toBe "20px"
|
|
expect($("atom-text-editor").css("padding-bottom")).toBe "30px"
|
|
|
|
describe "reloading a theme", ->
|
|
beforeEach ->
|
|
themePath = atom.project.getDirectories()[0]?.resolve('packages/theme-with-package-file')
|
|
theme = new ThemePackage(themePath)
|
|
theme.activate()
|
|
|
|
it "reloads without readding to the stylesheets list", ->
|
|
expect(theme.getStylesheetPaths().length).toBe 3
|
|
theme.reloadStylesheets()
|
|
expect(theme.getStylesheetPaths().length).toBe 3
|
|
|
|
describe "events", ->
|
|
beforeEach ->
|
|
themePath = atom.project.getDirectories()[0]?.resolve('packages/theme-with-package-file')
|
|
theme = new ThemePackage(themePath)
|
|
theme.activate()
|
|
|
|
it "deactivated event fires on .deactivate()", ->
|
|
theme.onDidDeactivate spy = jasmine.createSpy()
|
|
theme.deactivate()
|
|
expect(spy).toHaveBeenCalled()
|