2013-09-25 19:39:16 +04:00
|
|
|
path = require 'path'
|
2014-01-17 23:08:43 +04:00
|
|
|
|
2014-02-24 05:19:00 +04:00
|
|
|
{$, $$, WorkspaceView} = require 'atom'
|
|
|
|
fs = require 'fs-plus'
|
2014-01-17 23:08:43 +04:00
|
|
|
temp = require 'temp'
|
2013-08-07 21:40:46 +04:00
|
|
|
|
2013-09-18 05:58:41 +04:00
|
|
|
ThemeManager = require '../src/theme-manager'
|
2014-02-18 00:59:03 +04:00
|
|
|
Package = require '../src/package'
|
2013-08-07 21:40:46 +04:00
|
|
|
|
2013-10-19 04:42:09 +04:00
|
|
|
describe "ThemeManager", ->
|
2013-08-20 06:45:13 +04:00
|
|
|
themeManager = null
|
2013-10-15 04:58:53 +04:00
|
|
|
resourcePath = atom.getLoadSettings().resourcePath
|
2013-11-11 23:47:24 +04:00
|
|
|
configDirPath = atom.getConfigDirPath()
|
2013-08-20 06:45:13 +04:00
|
|
|
|
|
|
|
beforeEach ->
|
2013-11-11 23:47:24 +04:00
|
|
|
themeManager = new ThemeManager({packageManager: atom.packages, resourcePath, configDirPath})
|
2013-08-20 06:45:13 +04:00
|
|
|
|
|
|
|
afterEach ->
|
2013-10-19 02:24:39 +04:00
|
|
|
themeManager.deactivateThemes()
|
|
|
|
|
|
|
|
describe "theme getters and setters", ->
|
|
|
|
beforeEach ->
|
2014-05-21 19:55:40 +04:00
|
|
|
atom.packages.loadPackages()
|
2013-10-19 02:24:39 +04:00
|
|
|
|
|
|
|
it 'getLoadedThemes get all the loaded themes', ->
|
|
|
|
themes = themeManager.getLoadedThemes()
|
2013-10-21 22:37:01 +04:00
|
|
|
expect(themes.length).toBeGreaterThan(2)
|
2013-10-19 02:24:39 +04:00
|
|
|
|
|
|
|
it 'getActiveThemes get all the active themes', ->
|
2014-02-07 23:21:52 +04:00
|
|
|
waitsForPromise ->
|
|
|
|
themeManager.activateThemes()
|
|
|
|
|
|
|
|
runs ->
|
|
|
|
names = atom.config.get('core.themes')
|
|
|
|
expect(names.length).toBeGreaterThan(0)
|
|
|
|
themes = themeManager.getActiveThemes()
|
|
|
|
expect(themes).toHaveLength(names.length)
|
2013-08-20 06:45:13 +04:00
|
|
|
|
2014-04-18 00:31:43 +04:00
|
|
|
describe "when the core.themes config value contains invalid entry", ->
|
2014-04-22 20:51:00 +04:00
|
|
|
it "ignores theme", ->
|
2014-04-18 00:31:43 +04:00
|
|
|
atom.config.set 'core.themes', [
|
|
|
|
'atom-light-ui'
|
|
|
|
null
|
|
|
|
undefined
|
|
|
|
''
|
|
|
|
false
|
|
|
|
4
|
|
|
|
{}
|
|
|
|
[]
|
|
|
|
'atom-dark-ui'
|
|
|
|
]
|
|
|
|
|
|
|
|
expect(themeManager.getEnabledThemeNames()).toEqual ['atom-dark-ui', 'atom-light-ui']
|
|
|
|
|
2014-10-01 00:01:41 +04:00
|
|
|
describe "::getImportPaths()", ->
|
2013-09-03 23:22:32 +04:00
|
|
|
it "returns the theme directories before the themes are loaded", ->
|
2013-12-07 01:24:34 +04:00
|
|
|
atom.config.set('core.themes', ['theme-with-index-less', 'atom-dark-ui', 'atom-light-ui'])
|
2013-09-03 23:22:32 +04:00
|
|
|
|
|
|
|
paths = themeManager.getImportPaths()
|
|
|
|
|
|
|
|
# syntax theme is not a dir at this time, so only two.
|
|
|
|
expect(paths.length).toBe 2
|
2014-01-16 05:42:17 +04:00
|
|
|
expect(paths[0]).toContain 'atom-light-ui'
|
|
|
|
expect(paths[1]).toContain 'atom-dark-ui'
|
2013-09-03 23:22:32 +04:00
|
|
|
|
2013-10-02 22:24:24 +04:00
|
|
|
it "ignores themes that cannot be resolved to a directory", ->
|
2013-11-11 21:16:44 +04:00
|
|
|
atom.config.set('core.themes', ['definitely-not-a-theme'])
|
2013-10-02 22:24:24 +04:00
|
|
|
expect(-> themeManager.getImportPaths()).not.toThrow()
|
|
|
|
|
2013-08-07 21:40:46 +04:00
|
|
|
describe "when the core.themes config value changes", ->
|
|
|
|
it "add/removes stylesheets to reflect the new config value", ->
|
2014-09-10 02:24:55 +04:00
|
|
|
themeManager.onDidReloadAll reloadHandler = jasmine.createSpy()
|
2013-08-07 21:40:46 +04:00
|
|
|
spyOn(themeManager, 'getUserStylesheetPath').andCallFake -> null
|
2013-08-14 04:01:45 +04:00
|
|
|
|
2014-02-07 23:21:52 +04:00
|
|
|
waitsForPromise ->
|
|
|
|
themeManager.activateThemes()
|
|
|
|
|
|
|
|
runs ->
|
|
|
|
reloadHandler.reset()
|
|
|
|
atom.config.set('core.themes', [])
|
|
|
|
|
|
|
|
waitsFor ->
|
|
|
|
reloadHandler.callCount == 1
|
|
|
|
|
|
|
|
runs ->
|
|
|
|
reloadHandler.reset()
|
|
|
|
expect($('style.theme')).toHaveLength 0
|
|
|
|
atom.config.set('core.themes', ['atom-dark-syntax'])
|
|
|
|
|
|
|
|
waitsFor ->
|
|
|
|
reloadHandler.callCount == 1
|
|
|
|
|
|
|
|
runs ->
|
|
|
|
reloadHandler.reset()
|
|
|
|
expect($('style.theme')).toHaveLength 1
|
|
|
|
expect($('style.theme:eq(0)').attr('id')).toMatch /atom-dark-syntax/
|
|
|
|
atom.config.set('core.themes', ['atom-light-syntax', 'atom-dark-syntax'])
|
|
|
|
|
|
|
|
waitsFor ->
|
|
|
|
reloadHandler.callCount == 1
|
2013-08-07 21:40:46 +04:00
|
|
|
|
2014-02-07 23:21:52 +04:00
|
|
|
runs ->
|
|
|
|
reloadHandler.reset()
|
|
|
|
expect($('style.theme')).toHaveLength 2
|
|
|
|
expect($('style.theme:eq(0)').attr('id')).toMatch /atom-dark-syntax/
|
|
|
|
expect($('style.theme:eq(1)').attr('id')).toMatch /atom-light-syntax/
|
|
|
|
atom.config.set('core.themes', [])
|
2013-08-07 21:40:46 +04:00
|
|
|
|
2014-02-07 23:21:52 +04:00
|
|
|
waitsFor ->
|
|
|
|
reloadHandler.callCount == 1
|
2013-08-07 21:40:46 +04:00
|
|
|
|
2014-02-07 23:21:52 +04:00
|
|
|
runs ->
|
|
|
|
reloadHandler.reset()
|
|
|
|
expect($('style.theme')).toHaveLength 0
|
|
|
|
# atom-dark-ui has an directory path, the syntax one doesn't
|
|
|
|
atom.config.set('core.themes', ['theme-with-index-less', 'atom-dark-ui'])
|
2013-08-09 22:24:21 +04:00
|
|
|
|
2014-02-07 23:21:52 +04:00
|
|
|
waitsFor ->
|
|
|
|
reloadHandler.callCount == 1
|
|
|
|
|
|
|
|
runs ->
|
|
|
|
expect($('style.theme')).toHaveLength 2
|
|
|
|
importPaths = themeManager.getImportPaths()
|
|
|
|
expect(importPaths.length).toBe 1
|
|
|
|
expect(importPaths[0]).toContain 'atom-dark-ui'
|
2013-08-14 03:51:21 +04:00
|
|
|
|
2013-08-09 22:24:21 +04:00
|
|
|
describe "when a theme fails to load", ->
|
|
|
|
it "logs a warning", ->
|
|
|
|
spyOn(console, 'warn')
|
2013-10-19 04:41:32 +04:00
|
|
|
expect(-> atom.packages.activatePackage('a-theme-that-will-not-be-found')).toThrow()
|
2013-09-25 19:39:16 +04:00
|
|
|
|
2014-10-01 00:01:41 +04:00
|
|
|
describe "::requireStylesheet(path)", ->
|
2013-09-25 19:39:16 +04:00
|
|
|
it "synchronously loads css at the given path and installs a style tag for it in the head", ->
|
2014-09-10 02:35:00 +04:00
|
|
|
themeManager.onDidChangeStylesheets stylesheetsChangedHandler = jasmine.createSpy("stylesheetsChangedHandler")
|
|
|
|
themeManager.onDidAddStylesheet stylesheetAddedHandler = jasmine.createSpy("stylesheetAddedHandler")
|
2013-11-21 03:35:49 +04:00
|
|
|
cssPath = atom.project.resolve('css.css')
|
2013-09-25 19:39:16 +04:00
|
|
|
lengthBefore = $('head style').length
|
|
|
|
|
|
|
|
themeManager.requireStylesheet(cssPath)
|
|
|
|
expect($('head style').length).toBe lengthBefore + 1
|
|
|
|
|
2014-05-06 04:54:22 +04:00
|
|
|
expect(stylesheetAddedHandler).toHaveBeenCalled()
|
|
|
|
expect(stylesheetsChangedHandler).toHaveBeenCalled()
|
|
|
|
|
2013-09-25 19:39:16 +04:00
|
|
|
element = $('head style[id*="css.css"]')
|
2013-11-07 05:12:47 +04:00
|
|
|
expect(element.attr('id')).toBe themeManager.stringToId(cssPath)
|
2013-11-01 01:58:01 +04:00
|
|
|
expect(element.text()).toBe fs.readFileSync(cssPath, 'utf8')
|
2014-05-06 04:54:22 +04:00
|
|
|
expect(element[0].sheet).toBe stylesheetAddedHandler.argsForCall[0][0]
|
2013-09-25 19:39:16 +04:00
|
|
|
|
|
|
|
# doesn't append twice
|
|
|
|
themeManager.requireStylesheet(cssPath)
|
|
|
|
expect($('head style').length).toBe lengthBefore + 1
|
|
|
|
|
|
|
|
$('head style[id*="css.css"]').remove()
|
|
|
|
|
|
|
|
it "synchronously loads and parses less files at the given path and installs a style tag for it in the head", ->
|
2013-11-21 03:35:49 +04:00
|
|
|
lessPath = atom.project.resolve('sample.less')
|
2013-09-25 19:39:16 +04:00
|
|
|
lengthBefore = $('head style').length
|
|
|
|
themeManager.requireStylesheet(lessPath)
|
|
|
|
expect($('head style').length).toBe lengthBefore + 1
|
|
|
|
|
|
|
|
element = $('head style[id*="sample.less"]')
|
2013-11-07 05:12:47 +04:00
|
|
|
expect(element.attr('id')).toBe themeManager.stringToId(lessPath)
|
2013-09-25 19:39:16 +04:00
|
|
|
expect(element.text()).toBe """
|
|
|
|
#header {
|
|
|
|
color: #4d926f;
|
|
|
|
}
|
|
|
|
h2 {
|
|
|
|
color: #4d926f;
|
|
|
|
}
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
# doesn't append twice
|
|
|
|
themeManager.requireStylesheet(lessPath)
|
|
|
|
expect($('head style').length).toBe lengthBefore + 1
|
|
|
|
$('head style[id*="sample.less"]').remove()
|
|
|
|
|
|
|
|
it "supports requiring css and less stylesheets without an explicit extension", ->
|
|
|
|
themeManager.requireStylesheet path.join(__dirname, 'fixtures', 'css')
|
2013-11-21 04:59:37 +04:00
|
|
|
expect($('head style[id*="css.css"]').attr('id')).toBe themeManager.stringToId(atom.project.resolve('css.css'))
|
2013-09-25 19:39:16 +04:00
|
|
|
themeManager.requireStylesheet path.join(__dirname, 'fixtures', 'sample')
|
2013-11-21 04:59:37 +04:00
|
|
|
expect($('head style[id*="sample.less"]').attr('id')).toBe themeManager.stringToId(atom.project.resolve('sample.less'))
|
2013-09-25 19:39:16 +04:00
|
|
|
|
|
|
|
$('head style[id*="css.css"]').remove()
|
|
|
|
$('head style[id*="sample.less"]').remove()
|
|
|
|
|
|
|
|
describe ".removeStylesheet(path)", ->
|
|
|
|
it "removes styling applied by given stylesheet path", ->
|
|
|
|
cssPath = require.resolve('./fixtures/css.css')
|
|
|
|
|
|
|
|
expect($(document.body).css('font-weight')).not.toBe("bold")
|
|
|
|
themeManager.requireStylesheet(cssPath)
|
|
|
|
expect($(document.body).css('font-weight')).toBe("bold")
|
2014-03-20 00:43:31 +04:00
|
|
|
|
2014-09-10 02:35:00 +04:00
|
|
|
themeManager.onDidRemoveStylesheet stylesheetRemovedHandler = jasmine.createSpy("stylesheetRemovedHandler")
|
|
|
|
themeManager.onDidChangeStylesheets stylesheetsChangedHandler = jasmine.createSpy("stylesheetsChangedHandler")
|
2014-05-06 04:54:22 +04:00
|
|
|
|
2013-09-25 19:39:16 +04:00
|
|
|
themeManager.removeStylesheet(cssPath)
|
2014-05-06 04:54:22 +04:00
|
|
|
|
2013-09-25 19:39:16 +04:00
|
|
|
expect($(document.body).css('font-weight')).not.toBe("bold")
|
2014-05-06 04:54:22 +04:00
|
|
|
|
|
|
|
expect(stylesheetRemovedHandler).toHaveBeenCalled()
|
|
|
|
stylesheet = stylesheetRemovedHandler.argsForCall[0][0]
|
|
|
|
expect(stylesheet instanceof CSSStyleSheet).toBe true
|
|
|
|
expect(stylesheet.cssRules[0].selectorText).toBe 'body'
|
|
|
|
|
2014-03-20 00:43:31 +04:00
|
|
|
expect(stylesheetsChangedHandler).toHaveBeenCalled()
|
2013-09-25 19:39:16 +04:00
|
|
|
|
|
|
|
describe "base stylesheet loading", ->
|
|
|
|
beforeEach ->
|
2014-09-17 04:06:23 +04:00
|
|
|
atom.workspaceView = atom.workspace.getView(atom.workspace).__spacePenView
|
2013-11-26 22:11:31 +04:00
|
|
|
atom.workspaceView.append $$ -> @div class: 'editor'
|
|
|
|
atom.workspaceView.attachToDom()
|
2014-02-07 23:21:52 +04:00
|
|
|
|
|
|
|
waitsForPromise ->
|
|
|
|
themeManager.activateThemes()
|
2013-09-25 19:39:16 +04:00
|
|
|
|
|
|
|
it "loads the correct values from the theme's ui-variables file", ->
|
2014-09-10 02:35:00 +04:00
|
|
|
themeManager.onDidReloadAll reloadHandler = jasmine.createSpy()
|
2013-11-11 21:16:44 +04:00
|
|
|
atom.config.set('core.themes', ['theme-with-ui-variables'])
|
2013-09-25 19:39:16 +04:00
|
|
|
|
2014-02-07 23:21:52 +04:00
|
|
|
waitsFor ->
|
|
|
|
reloadHandler.callCount > 0
|
|
|
|
|
|
|
|
runs ->
|
|
|
|
# an override loaded in the base css
|
|
|
|
expect(atom.workspaceView.css("background-color")).toBe "rgb(0, 0, 255)"
|
2013-09-25 19:39:16 +04:00
|
|
|
|
2014-02-07 23:21:52 +04:00
|
|
|
# from within the theme itself
|
|
|
|
expect($(".editor").css("padding-top")).toBe "150px"
|
|
|
|
expect($(".editor").css("padding-right")).toBe "150px"
|
|
|
|
expect($(".editor").css("padding-bottom")).toBe "150px"
|
2014-01-17 23:08:43 +04:00
|
|
|
|
2014-07-12 01:04:54 +04:00
|
|
|
describe "when there is a theme with incomplete variables", ->
|
|
|
|
it "loads the correct values from the fallback ui-variables", ->
|
2014-09-10 02:35:00 +04:00
|
|
|
themeManager.onDidReloadAll reloadHandler = jasmine.createSpy()
|
2014-07-12 01:04:54 +04:00
|
|
|
atom.config.set('core.themes', ['theme-with-incomplete-ui-variables'])
|
|
|
|
|
|
|
|
waitsFor ->
|
|
|
|
reloadHandler.callCount > 0
|
|
|
|
|
|
|
|
runs ->
|
|
|
|
# an override loaded in the base css
|
|
|
|
expect(atom.workspaceView.css("background-color")).toBe "rgb(0, 0, 255)"
|
|
|
|
|
|
|
|
# from within the theme itself
|
|
|
|
expect($(".editor").css("background-color")).toBe "rgb(0, 152, 255)"
|
|
|
|
|
2014-08-21 22:53:10 +04:00
|
|
|
describe "theme classes on the workspace", ->
|
|
|
|
it 'adds theme-* classes to the workspace for each active theme', ->
|
|
|
|
expect(atom.workspaceView).toHaveClass 'theme-atom-dark-ui'
|
|
|
|
|
2014-09-10 02:35:00 +04:00
|
|
|
themeManager.onDidReloadAll reloadHandler = jasmine.createSpy()
|
2014-08-21 22:53:10 +04:00
|
|
|
atom.config.set('core.themes', ['theme-with-ui-variables'])
|
|
|
|
|
|
|
|
waitsFor ->
|
|
|
|
reloadHandler.callCount > 0
|
|
|
|
|
|
|
|
runs ->
|
|
|
|
# `theme-` twice as it prefixes the name with `theme-`
|
|
|
|
expect(atom.workspaceView).toHaveClass 'theme-theme-with-ui-variables'
|
|
|
|
expect(atom.workspaceView).not.toHaveClass 'theme-atom-dark-ui'
|
|
|
|
|
2014-01-17 23:08:43 +04:00
|
|
|
describe "when the user stylesheet changes", ->
|
|
|
|
it "reloads it", ->
|
2014-05-06 04:54:22 +04:00
|
|
|
[stylesheetRemovedHandler, stylesheetAddedHandler, stylesheetsChangedHandler] = []
|
2014-02-25 04:14:05 +04:00
|
|
|
userStylesheetPath = path.join(temp.mkdirSync("atom"), 'styles.less')
|
2014-01-17 23:08:43 +04:00
|
|
|
fs.writeFileSync(userStylesheetPath, 'body {border-style: dotted !important;}')
|
|
|
|
spyOn(themeManager, 'getUserStylesheetPath').andReturn userStylesheetPath
|
|
|
|
|
2014-02-07 23:21:52 +04:00
|
|
|
waitsForPromise ->
|
|
|
|
themeManager.activateThemes()
|
2014-01-17 23:08:43 +04:00
|
|
|
|
2014-02-07 23:21:52 +04:00
|
|
|
runs ->
|
2014-09-10 02:35:00 +04:00
|
|
|
themeManager.onDidChangeStylesheets stylesheetsChangedHandler = jasmine.createSpy("stylesheetsChangedHandler")
|
|
|
|
themeManager.onDidRemoveStylesheet stylesheetRemovedHandler = jasmine.createSpy("stylesheetRemovedHandler")
|
|
|
|
themeManager.onDidAddStylesheet stylesheetAddedHandler = jasmine.createSpy("stylesheetAddedHandler")
|
2014-02-07 23:21:52 +04:00
|
|
|
spyOn(themeManager, 'loadUserStylesheet').andCallThrough()
|
2014-05-06 04:54:22 +04:00
|
|
|
|
|
|
|
expect($(document.body).css('border-style')).toBe 'dotted'
|
2014-02-07 23:21:52 +04:00
|
|
|
fs.writeFileSync(userStylesheetPath, 'body {border-style: dashed}')
|
2014-01-17 23:08:43 +04:00
|
|
|
|
|
|
|
waitsFor ->
|
|
|
|
themeManager.loadUserStylesheet.callCount is 1
|
|
|
|
|
|
|
|
runs ->
|
|
|
|
expect($(document.body).css('border-style')).toBe 'dashed'
|
2014-05-06 04:54:22 +04:00
|
|
|
|
|
|
|
expect(stylesheetRemovedHandler).toHaveBeenCalled()
|
|
|
|
expect(stylesheetRemovedHandler.argsForCall[0][0].cssRules[0].style.border).toBe 'dotted'
|
|
|
|
|
|
|
|
expect(stylesheetAddedHandler).toHaveBeenCalled()
|
|
|
|
expect(stylesheetAddedHandler.argsForCall[0][0].cssRules[0].style.border).toBe 'dashed'
|
|
|
|
|
2014-03-20 00:43:31 +04:00
|
|
|
expect(stylesheetsChangedHandler).toHaveBeenCalled()
|
2014-05-06 04:54:22 +04:00
|
|
|
|
|
|
|
stylesheetRemovedHandler.reset()
|
2014-03-20 00:43:31 +04:00
|
|
|
stylesheetsChangedHandler.reset()
|
2014-01-17 23:08:43 +04:00
|
|
|
fs.removeSync(userStylesheetPath)
|
|
|
|
|
|
|
|
waitsFor ->
|
|
|
|
themeManager.loadUserStylesheet.callCount is 2
|
|
|
|
|
|
|
|
runs ->
|
2014-05-06 04:54:22 +04:00
|
|
|
expect(stylesheetRemovedHandler).toHaveBeenCalled()
|
|
|
|
expect(stylesheetRemovedHandler.argsForCall[0][0].cssRules[0].style.border).toBe 'dashed'
|
2014-01-17 23:08:43 +04:00
|
|
|
expect($(document.body).css('border-style')).toBe 'none'
|
2014-03-20 00:43:31 +04:00
|
|
|
expect(stylesheetsChangedHandler).toHaveBeenCalled()
|
2014-02-20 23:41:23 +04:00
|
|
|
|
|
|
|
describe "when a non-existent theme is present in the config", ->
|
|
|
|
it "logs a warning but does not throw an exception (regression)", ->
|
2014-05-20 21:11:35 +04:00
|
|
|
reloaded = false
|
|
|
|
|
2014-02-20 23:41:23 +04:00
|
|
|
waitsForPromise ->
|
|
|
|
themeManager.activateThemes()
|
|
|
|
|
|
|
|
runs ->
|
2014-09-10 02:35:00 +04:00
|
|
|
disposable = themeManager.onDidReloadAll ->
|
|
|
|
disposable.dispose()
|
|
|
|
reloaded = true
|
2014-02-20 23:41:23 +04:00
|
|
|
spyOn(console, 'warn')
|
|
|
|
expect(-> atom.config.set('core.themes', ['atom-light-ui', 'theme-really-does-not-exist'])).not.toThrow()
|
2014-05-16 19:14:21 +04:00
|
|
|
|
2014-05-20 21:11:35 +04:00
|
|
|
waitsFor -> reloaded
|
2014-05-16 19:14:21 +04:00
|
|
|
|
|
|
|
runs ->
|
2014-02-20 23:41:23 +04:00
|
|
|
expect(console.warn.callCount).toBe 1
|
|
|
|
expect(console.warn.argsForCall[0][0].length).toBeGreaterThan 0
|
2014-08-05 15:32:16 +04:00
|
|
|
|
2014-08-12 02:24:49 +04:00
|
|
|
describe "when in safe mode", ->
|
2014-08-05 15:32:16 +04:00
|
|
|
beforeEach ->
|
2014-08-08 21:59:45 +04:00
|
|
|
themeManager = new ThemeManager({packageManager: atom.packages, resourcePath, configDirPath, safeMode: true})
|
2014-08-05 15:32:16 +04:00
|
|
|
|
2014-08-12 02:24:49 +04:00
|
|
|
describe 'when the enabled UI and syntax themes are bundled with Atom', ->
|
|
|
|
beforeEach ->
|
|
|
|
atom.config.set('core.themes', ['atom-light-ui', 'atom-dark-syntax'])
|
2014-08-05 15:32:16 +04:00
|
|
|
|
2014-08-12 02:24:49 +04:00
|
|
|
waitsForPromise ->
|
|
|
|
themeManager.activateThemes()
|
|
|
|
|
|
|
|
it 'uses the enabled themes', ->
|
|
|
|
activeThemeNames = themeManager.getActiveNames()
|
|
|
|
expect(activeThemeNames.length).toBe(2)
|
|
|
|
expect(activeThemeNames).toContain('atom-light-ui')
|
|
|
|
expect(activeThemeNames).toContain('atom-dark-syntax')
|
|
|
|
|
|
|
|
describe 'when the enabled UI and syntax themes are not bundled with Atom', ->
|
|
|
|
beforeEach ->
|
|
|
|
atom.config.set('core.themes', ['installed-dark-ui', 'installed-dark-syntax'])
|
|
|
|
|
|
|
|
waitsForPromise ->
|
|
|
|
themeManager.activateThemes()
|
|
|
|
|
|
|
|
it 'uses the default dark UI and syntax themes', ->
|
|
|
|
activeThemeNames = themeManager.getActiveNames()
|
|
|
|
expect(activeThemeNames.length).toBe(2)
|
|
|
|
expect(activeThemeNames).toContain('atom-dark-ui')
|
|
|
|
expect(activeThemeNames).toContain('atom-dark-syntax')
|
|
|
|
|
|
|
|
describe 'when the enabled UI theme is not bundled with Atom', ->
|
|
|
|
beforeEach ->
|
|
|
|
atom.config.set('core.themes', ['installed-dark-ui', 'atom-light-syntax'])
|
|
|
|
|
|
|
|
waitsForPromise ->
|
|
|
|
themeManager.activateThemes()
|
|
|
|
|
|
|
|
it 'uses the default dark UI theme', ->
|
2014-08-05 15:32:16 +04:00
|
|
|
activeThemeNames = themeManager.getActiveNames()
|
|
|
|
expect(activeThemeNames.length).toBe(2)
|
|
|
|
expect(activeThemeNames).toContain('atom-dark-ui')
|
2014-08-12 02:24:49 +04:00
|
|
|
expect(activeThemeNames).toContain('atom-light-syntax')
|
|
|
|
|
|
|
|
describe 'when the enabled syntax theme is not bundled with Atom', ->
|
|
|
|
beforeEach ->
|
|
|
|
atom.config.set('core.themes', ['atom-light-ui', 'installed-dark-syntax'])
|
|
|
|
|
|
|
|
waitsForPromise ->
|
|
|
|
themeManager.activateThemes()
|
|
|
|
|
|
|
|
it 'uses the default dark syntax theme', ->
|
|
|
|
activeThemeNames = themeManager.getActiveNames()
|
|
|
|
expect(activeThemeNames.length).toBe(2)
|
|
|
|
expect(activeThemeNames).toContain('atom-light-ui')
|
2014-08-05 15:32:16 +04:00
|
|
|
expect(activeThemeNames).toContain('atom-dark-syntax')
|