import React from 'react';
import ReactDOM from 'react-dom';
import TestUtils from 'react-addons-test-utils';
import ItemValue from '../../src/main/js/apps/system/item-value';
let expect = require('chai').expect;
let sinon = require('sinon');
describe('System', function () {
describe('Item Value', function () {
it('should render string', () => {
let result = TestUtils.renderIntoDocument();
let content = ReactDOM.findDOMNode(TestUtils.findRenderedDOMComponentWithTag(result, 'code'));
expect(content.textContent).to.equal('/some/path/as/an/example');
});
it('should render `true`', () => {
let result = TestUtils.renderIntoDocument();
TestUtils.findRenderedDOMComponentWithClass(result, 'icon-check');
});
it('should render `false`', () => {
let result = TestUtils.renderIntoDocument();
TestUtils.findRenderedDOMComponentWithClass(result, 'icon-delete');
});
it('should render object', () => {
let result = TestUtils.renderIntoDocument();
TestUtils.findRenderedDOMComponentWithTag(result, 'table');
expect(TestUtils.scryRenderedDOMComponentsWithTag(result, 'tr')).to.have.length(2);
});
it('should render `true` inside object', () => {
let result = TestUtils.renderIntoDocument();
TestUtils.findRenderedDOMComponentWithTag(result, 'table');
TestUtils.findRenderedDOMComponentWithClass(result, 'icon-check');
});
it('should render object inside object', () => {
let result = TestUtils.renderIntoDocument(
);
expect(TestUtils.scryRenderedDOMComponentsWithTag(result, 'table')).to.have.length(3);
expect(TestUtils.scryRenderedDOMComponentsWithTag(result, 'tr')).to.have.length(6);
});
});
describe('Log Level', function () {
var previousFetch, fetchUrl, fetchOptions;
before(function () {
previousFetch = window.fetch;
window.fetch = function (url, options) {
fetchUrl = url;
fetchOptions = options;
return Promise.resolve();
};
});
after(function () {
window.fetch = previousFetch;
});
it('should render select box', () => {
let result = TestUtils.renderIntoDocument();
TestUtils.findRenderedDOMComponentWithTag(result, 'select');
expect(TestUtils.scryRenderedDOMComponentsWithTag(result, 'option')).to.have.length(3);
});
it('should set initial value', () => {
let result = TestUtils.renderIntoDocument();
let select = ReactDOM.findDOMNode(TestUtils.findRenderedDOMComponentWithTag(result, 'select'));
expect(select.value).to.equal('DEBUG');
});
it('should render warning', () => {
let result = TestUtils.renderIntoDocument();
TestUtils.findRenderedDOMComponentWithClass(result, 'alert');
});
it('should not render warning', () => {
let result = TestUtils.renderIntoDocument();
expect(TestUtils.scryRenderedDOMComponentsWithClass(result, 'alert')).to.be.empty;
});
it('should change value', () => {
let result = TestUtils.renderIntoDocument();
let select = ReactDOM.findDOMNode(TestUtils.findRenderedDOMComponentWithTag(result, 'select'));
select.value = 'TRACE';
TestUtils.Simulate.change(select);
expect(fetchUrl).to.equal('/api/system/change_log_level');
expect(fetchOptions.method).to.equal('POST');
expect(fetchOptions.body).to.equal('level=TRACE');
});
});
});