spec: Test the -able methods

This commit is contained in:
Cheng Zhao 2016-01-23 03:35:30 -08:00
parent 010cc3276a
commit c41de501cb
4 changed files with 113 additions and 8 deletions

View file

@ -122,7 +122,7 @@ void NativeWindow::InitFromOptions(const mate::Dictionary& options) {
} }
#endif #endif
bool movable; bool movable;
if (options.Get(options::kMovable, &movable) && movable) { if (options.Get(options::kMovable, &movable)) {
SetMovable(movable); SetMovable(movable);
} }
bool has_shadow; bool has_shadow;

View file

@ -489,9 +489,7 @@ NativeWindowMac::NativeWindowMac(
bool fullscreen = false; bool fullscreen = false;
if (options.Get(options::kFullscreen, &fullscreen) && !fullscreen) if (options.Get(options::kFullscreen, &fullscreen) && !fullscreen)
fullscreenable = false; fullscreenable = false;
if (!fullscreenable) { SetFullScreenable(fullscreenable);
SetFullScreenable(false);
}
// Disable zoom button if window is not resizable // Disable zoom button if window is not resizable
if (!maximizable) { if (!maximizable) {

View file

@ -465,9 +465,9 @@ void NativeWindowViews::SetMinimizable(bool minimizable) {
bool NativeWindowViews::IsMinimizable() { bool NativeWindowViews::IsMinimizable() {
#if defined(OS_WIN) #if defined(OS_WIN)
return CanMinimize(); return ::GetWindowLong(GetAcceleratedWidget(), GWL_STYLE) & WS_MINIMIZEBOX;
#else #else
return true; // CanMinimize() Not implemented on Linux. return true; // Not implemented on Linux.
#endif #endif
} }
@ -480,9 +480,9 @@ void NativeWindowViews::SetMaximizable(bool maximizable) {
bool NativeWindowViews::IsMaximizable() { bool NativeWindowViews::IsMaximizable() {
#if defined(OS_WIN) #if defined(OS_WIN)
return CanMaximize(); return ::GetWindowLong(GetAcceleratedWidget(), GWL_STYLE) & WS_MAXIMIZEBOX;
#else #else
return true; // CanMaximize() Not implemented on Linux. return true; // Not implemented on Linux.
#endif #endif
} }

View file

@ -1,3 +1,5 @@
'use strict';
const assert = require('assert'); const assert = require('assert');
const fs = require('fs'); const fs = require('fs');
const path = require('path'); const path = require('path');
@ -306,6 +308,7 @@ describe('browser-window module', function() {
return assert.equal(after[1], size.height); return assert.equal(after[1], size.height);
}); });
}); });
describe('"web-preferences" option', function() { describe('"web-preferences" option', function() {
afterEach(function() { afterEach(function() {
return ipcMain.removeAllListeners('answer'); return ipcMain.removeAllListeners('answer');
@ -491,4 +494,108 @@ describe('browser-window module', function() {
return assert.equal(size[1], 600); return assert.equal(size[1], 600);
}); });
}); });
describe('window states', function() {
// Not implemented on Linux.
if (process.platform == 'linux')
return;
describe('movable state', function() {
it('can be changed with movable option', function() {
w.destroy();
w = new BrowserWindow({show: false, movable: false});
assert.equal(w.isMovable(), false);
});
it('can be changed with setMovable method', function() {
assert.equal(w.isMovable(), true);
w.setMovable(false);
assert.equal(w.isMovable(), false);
w.setMovable(true);
assert.equal(w.isMovable(), true);
});
});
describe('minimizable state', function() {
it('can be changed with minimizable option', function() {
w.destroy();
w = new BrowserWindow({show: false, minimizable: false});
assert.equal(w.isMinimizable(), false);
});
it('can be changed with setMinimizable method', function() {
assert.equal(w.isMinimizable(), true);
w.setMinimizable(false);
assert.equal(w.isMinimizable(), false);
w.setMinimizable(true);
assert.equal(w.isMinimizable(), true);
});
});
describe('maximizable state', function() {
it('can be changed with maximizable option', function() {
w.destroy();
w = new BrowserWindow({show: false, maximizable: false});
assert.equal(w.isMaximizable(), false);
});
it('can be changed with setMaximizable method', function() {
assert.equal(w.isMaximizable(), true);
w.setMaximizable(false);
assert.equal(w.isMaximizable(), false);
w.setMaximizable(true);
assert.equal(w.isMaximizable(), true);
});
it('is not affected when changing other states', function() {
w.setMaximizable(false);
assert.equal(w.isMaximizable(), false);
w.setMinimizable(false);
assert.equal(w.isMaximizable(), false);
w.setClosable(false);
assert.equal(w.isMaximizable(), false);
});
});
describe('fullscreenable state', function() {
// Only implemented on OS X.
if (process.platform != 'darwin')
return;
it('can be changed with fullscreenable option', function() {
w.destroy();
w = new BrowserWindow({show: false, fullscreenable: false});
assert.equal(w.isFullScreenable(), false);
});
it('can be changed with setFullScreenable method', function() {
assert.equal(w.isFullScreenable(), true);
w.setFullScreenable(false);
assert.equal(w.isFullScreenable(), false);
w.setFullScreenable(true);
assert.equal(w.isFullScreenable(), true);
});
});
describe('closable state', function() {
// Only implemented on OS X.
if (process.platform != 'darwin')
return;
it('can be changed with closable option', function() {
w.destroy();
w = new BrowserWindow({show: false, closable: false});
assert.equal(w.isClosable(), false);
});
it('can be changed with setClosable method', function() {
assert.equal(w.isClosable(), true);
w.setClosable(false);
assert.equal(w.isClosable(), false);
w.setClosable(true);
assert.equal(w.isClosable(), true);
});
});
});
}); });