Files
RaspiWifi-Node/tests/node_modules/wireless-tools/test/wpa_cli.js
2022-08-26 12:49:14 +02:00

660 lines
21 KiB
JavaScript

/*
* Copyright (c) 2015 Christopher M. Baker
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
*/
var should = require('should');
var wpa_cli = require('../wpa_cli');
var WPA_CLI_STATUS_SILENCE = '';
var WPA_CLI_STATUS_COMPLETED = [
'bssid=2c:f5:d3:02:ea:d9',
'freq=2412',
'ssid=Fake-Wifi',
'id=0',
'mode=station',
'pairwise_cipher=CCMP',
'group_cipher=CCMP',
'key_mgmt=WPA2-PSK',
'wpa_state=COMPLETED',
'ip_address=10.34.141.168',
'p2p_device_address=e4:28:9c:a8:53:72',
'address=e4:28:9c:a8:53:72',
'uuid=e1cda789-8c88-53e8-ffff-31c304580c1e'
].join('\n');
var WPA_CLI_STATUS_4WAY_HANDSHAKE = [
'bssid=2c:f5:d3:02:ea:d9',
'freq=2412',
'ssid=Fake-Wifi',
'id=0',
'mode=station',
'pairwise_cipher=CCMP',
'group_cipher=CCMP',
'key_mgmt=WPA2-PSK',
'wpa_state=4WAY_HANDSHAKE',
'ip_address=10.34.141.168',
'p2p_device_address=e4:28:9c:a8:53:72',
'address=e4:28:9c:a8:53:72',
'uuid=e1cda789-8c88-53e8-ffff-31c304580c1e'
].join('\n');
var WPA_CLI_STATUS_SCANNING = [
'wpa_state=SCANNING',
'ip_address=10.34.141.168',
'p2p_device_address=e4:28:9c:a8:53:72',
'address=e4:28:9c:a8:53:72',
'uuid=e1cda789-8c88-53e8-ffff-31c304580c1e'
].join('\n');
var WPA_CLI_SCAN_RESULTS = [
'bssid / frequency / signal level / flags / ssid',
'2c:f5:d3:02:ea:d9 2472 -31 [WPA-PSK-CCMP+TKIP][WPA2-PSK-CCMP+TKIP][ESS] FakeWifi',
'2c:f5:d3:02:ea:d9 2472 -31 [WPA-PSK-CCMP+TKIP][WPA2-PSK-CCMP+TKIP][ESS] FakeWifi2'
].join('\n');
var WPA_CLI_SCAN_NORESULTS = [
''
].join('\n');
var WPA_CLI_COMMAND_OK = 'OK\n';
var WPA_CLI_COMMAND_FAIL = 'FAIL\n';
var WPA_CLI_COMMAND_ID = '0\n';
describe('wpa_cli', function() {
describe('wpa_cli.status(iface, callback)', function() {
before(function() {
this.OUTPUT = '';
var self = this;
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 status');
callback(null, self.OUTPUT);
};
});
it('status SILENCE', function (done) {
this.OUTPUT = WPA_CLI_STATUS_SILENCE;
wpa_cli.status('wlan0', function(err, status) {
should(status).eql({ });
done();
});
});
it('status COMPLETED', function(done) {
this.OUTPUT = WPA_CLI_STATUS_COMPLETED;
wpa_cli.status('wlan0', function(err, status) {
should(status).eql({
bssid: '2c:f5:d3:02:ea:d9',
frequency: 2412,
mode: 'station',
key_mgmt: 'wpa2-psk',
ssid: 'Fake-Wifi',
pairwise_cipher: 'CCMP',
group_cipher: 'CCMP',
p2p_device_address: 'e4:28:9c:a8:53:72',
wpa_state: 'COMPLETED',
ip: '10.34.141.168',
mac: 'e4:28:9c:a8:53:72',
uuid: 'e1cda789-8c88-53e8-ffff-31c304580c1e',
id: 0
});
done();
});
});
it('status 4WAY_HANDSHAKE', function(done) {
this.OUTPUT = WPA_CLI_STATUS_4WAY_HANDSHAKE;
wpa_cli.status('wlan0', function(err, status) {
should(status).eql({
bssid: '2c:f5:d3:02:ea:d9',
frequency: 2412,
mode: 'station',
key_mgmt: 'wpa2-psk',
ssid: 'Fake-Wifi',
pairwise_cipher: 'CCMP',
group_cipher: 'CCMP',
p2p_device_address: 'e4:28:9c:a8:53:72',
wpa_state: '4WAY_HANDSHAKE',
ip: '10.34.141.168',
mac: 'e4:28:9c:a8:53:72',
uuid: 'e1cda789-8c88-53e8-ffff-31c304580c1e',
id: 0
});
done();
});
});
it('status SCANNING', function(done) {
this.OUTPUT = WPA_CLI_STATUS_SCANNING;
wpa_cli.status('wlan0', function(err, status) {
should(status).eql({
p2p_device_address: 'e4:28:9c:a8:53:72',
wpa_state: 'SCANNING',
ip: '10.34.141.168',
mac: 'e4:28:9c:a8:53:72',
uuid: 'e1cda789-8c88-53e8-ffff-31c304580c1e' });
});
done();
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.status('wlan0', function(err, status) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.bssid(iface, ap, ssid, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 bssid Fake-Wifi 2c:f5:d3:02:ea:89');
callback(null, WPA_CLI_COMMAND_OK);
};
wpa_cli.bssid('wlan0', '2c:f5:d3:02:ea:89', 'Fake-Wifi', function(err, status) {
should(status).eql({
result: 'OK'
});
done();
});
});
it('FAIL result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 bssid 2c:f5:d3:02:ea:89 Fake-Wifi');
callback(null, WPA_CLI_COMMAND_FAIL);
};
wpa_cli.bssid('wlan0', 'Fake-Wifi', '2c:f5:d3:02:ea:89', function(err, status) {
should(err.message).eql('FAIL');
done();
});
});
it('Handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.bssid('wlan0', '2c:f5:d3:02:ea:89', 'Fake-Wifi', function(err, status) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.reassociate(iface, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 reassociate');
callback(null, WPA_CLI_COMMAND_OK);
};
wpa_cli.reassociate('wlan0', function(err, status) {
should(status).eql({
result: 'OK'
});
done();
});
});
it('FAIL result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 reassociate');
callback(null, WPA_CLI_COMMAND_FAIL);
};
wpa_cli.reassociate('wlan0', function(err, status) {
should(err.message).eql('FAIL');
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.reassociate('wlan0', function(err, status) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.set(iface, variable, value, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 set ap_scan 1');
callback(null, WPA_CLI_COMMAND_OK);
};
wpa_cli.set('wlan0','ap_scan', 1, function(err, status) {
should(status).eql({
result: 'OK'
});
done();
});
});
it('FAIL result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 set ap_scan 1');
callback(null, WPA_CLI_COMMAND_FAIL);
};
wpa_cli.set('wlan0','ap_scan', 1, function(err, status) {
should(err.message).eql('FAIL');
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.set('wlan0','ap_scan', 1, function(err, status) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.add_network(iface, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 add_network');
callback(null, WPA_CLI_COMMAND_ID);
};
wpa_cli.add_network('wlan0', function(err, status) {
should(status).eql({
result: '0'
});
done();
});
});
it('FAIL result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 add_network');
callback(null, WPA_CLI_COMMAND_FAIL);
};
wpa_cli.add_network('wlan0', function(err, status) {
should(err.message).eql('FAIL');
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.add_network('wlan0', function(err, status) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.set_network(iface, id, variable, value, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 set_network 0 scan_ssid 1');
callback(null, WPA_CLI_COMMAND_OK);
};
wpa_cli.set_network('wlan0', 0, 'scan_ssid', 1, function(err, status) {
should(status).eql({
result: 'OK'
});
done();
});
});
it('FAIL result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 set_network 0 fake_variable 1');
callback(null, WPA_CLI_COMMAND_FAIL);
};
wpa_cli.set_network('wlan0', 0, 'fake_variable', 1, function(err, status) {
should(err.message).eql('FAIL');
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.set_network('wlan0', 0, 'fake_variable', 1, function(err, status) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.enable_network(iface, id, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 enable_network 0');
callback(null, WPA_CLI_COMMAND_OK);
};
wpa_cli.enable_network('wlan0', 0, function(err, status) {
should(status).eql({
result: 'OK'
});
done();
});
});
it('FAIL result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 enable_network 28');
callback(null, WPA_CLI_COMMAND_FAIL);
};
wpa_cli.enable_network('wlan0', 28, function(err, status) {
should(err.message).eql('FAIL');
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.enable_network('wlan0', 28, function(err, status) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.disable_network(iface, id, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 disable_network 0');
callback(null, WPA_CLI_COMMAND_OK);
};
wpa_cli.disable_network('wlan0', 0, function(err, status) {
should(status).eql({
result: 'OK'
});
done();
});
});
it('FAIL result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 disable_network 28');
callback(null, WPA_CLI_COMMAND_FAIL);
};
wpa_cli.disable_network('wlan0', 28, function(err, status) {
should(err.message).eql('FAIL');
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.disable_network('wlan0', 28, function(err, status) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.remove_network(iface, id, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 remove_network 0');
callback(null, WPA_CLI_COMMAND_OK);
};
wpa_cli.remove_network('wlan0', 0, function(err, status) {
should(status).eql({
result: 'OK'
});
done();
});
});
it('FAIL result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 remove_network 28');
callback(null, WPA_CLI_COMMAND_FAIL);
};
wpa_cli.remove_network('wlan0', 28, function(err, status) {
should(err.message).eql('FAIL');
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.remove_network('wlan0', 28, function(err, status) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.select_network(iface, id, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 select_network 0');
callback(null, WPA_CLI_COMMAND_OK);
};
wpa_cli.select_network('wlan0', 0, function(err, status) {
should(status).eql({
result: 'OK'
});
done();
});
});
it('FAIL result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 select_network 28');
callback(null, WPA_CLI_COMMAND_FAIL);
};
wpa_cli.select_network('wlan0', 28, function(err, status) {
should(err.message).eql('FAIL');
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.select_network('wlan0', 28, function(err, status) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.scan(iface, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 scan');
callback(null, WPA_CLI_COMMAND_OK);
};
wpa_cli.scan('wlan0', function(err, scan) {
should(scan).eql({
result: 'OK'
});
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.scan('wlan0', function(err, scan) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.scan_results(iface, callback)', function(){
before(function() {
this.OUTPUT = '';
var self = this;
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 scan_results');
callback(null, self.OUTPUT);
};
});
it('scan_results NORESULTS', function (done) {
this.OUTPUT = WPA_CLI_SCAN_NORESULTS;
wpa_cli.scan_results('wlan0', function(err, results) {
should(results).eql([]);
done();
});
});
it('scan_results COMPLETED', function(done) {
this.OUTPUT = WPA_CLI_SCAN_RESULTS;
wpa_cli.scan_results('wlan0', function(err, results) {
should(results).eql([
{
bssid: '2c:f5:d3:02:ea:d9',
frequency: 2472,
signalLevel: -31,
flags: '[WPA-PSK-CCMP+TKIP][WPA2-PSK-CCMP+TKIP][ESS]',
ssid: 'FakeWifi'
},
{
bssid: '2c:f5:d3:02:ea:d9',
frequency: 2472,
signalLevel: -31,
flags: '[WPA-PSK-CCMP+TKIP][WPA2-PSK-CCMP+TKIP][ESS]',
ssid: 'FakeWifi2'
}
]);
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.scan_results('wlan0', function(err, results) {
should(err).eql('error');
done();
});
});
});
describe('wpa_cli.save_config(iface, callback)', function(){
it('OK result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 save_config');
callback(null, WPA_CLI_COMMAND_OK);
};
wpa_cli.save_config('wlan0', function(err, status) {
should(status).eql({
result: 'OK'
});
done();
});
});
it('FAIL result', function(done) {
wpa_cli.exec = function(command, callback) {
should(command).eql('wpa_cli -i wlan0 save_config');
callback(null, WPA_CLI_COMMAND_FAIL);
};
wpa_cli.save_config('wlan0', function(err, status) {
should(err.message).eql('FAIL');
done();
});
});
it('should handle errors', function(done) {
wpa_cli.exec = function(command, callback) {
callback('error');
};
wpa_cli.scan('wlan0', function(err, status) {
should(err).eql('error');
done();
});
});
});
});