mirror of
https://github.com/RaidMax/IW4M-Admin.git
synced 2025-07-01 01:20:49 -05:00
Add server version to master api
Add IsEvadedOffense to EFPenalty Fix remote log reading in not Windows
This commit is contained in:
173
Master/env_master/Lib/site-packages/pygal/test/test_line.py
Normal file
173
Master/env_master/Lib/site-packages/pygal/test/test_line.py
Normal file
@ -0,0 +1,173 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# This file is part of pygal
|
||||
#
|
||||
# A python svg graph plotting library
|
||||
# Copyright © 2012-2016 Kozea
|
||||
#
|
||||
# This library is free software: you can redistribute it and/or modify it under
|
||||
# the terms of the GNU Lesser General Public License as published by the Free
|
||||
# Software Foundation, either version 3 of the License, or (at your option) any
|
||||
# later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||||
# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
|
||||
# details.
|
||||
#
|
||||
# You should have received a copy of the GNU Lesser General Public License
|
||||
# along with pygal. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
"""Line chart related tests"""
|
||||
|
||||
from __future__ import division
|
||||
|
||||
from math import cos, sin
|
||||
|
||||
from pygal import Line
|
||||
from pygal.test.utils import texts
|
||||
|
||||
|
||||
def test_simple_line():
|
||||
"""Simple line test"""
|
||||
line = Line()
|
||||
rng = range(-30, 31, 5)
|
||||
line.add('test1', [cos(x / 10) for x in rng])
|
||||
line.add('test2', [sin(x / 10) for x in rng])
|
||||
line.add('test3', [cos(x / 10) - sin(x / 10) for x in rng])
|
||||
line.x_labels = map(str, rng)
|
||||
line.title = "cos sin and cos - sin"
|
||||
q = line.render_pyquery()
|
||||
assert len(q(".axis.x")) == 1
|
||||
assert len(q(".axis.y")) == 1
|
||||
assert len(q(".plot .series path")) == 3
|
||||
assert len(q(".legend")) == 3
|
||||
assert len(q(".x.axis .guides")) == 13
|
||||
assert len(q(".y.axis .guides")) == 13
|
||||
assert len(q(".dots")) == 3 * 13
|
||||
assert q(".axis.x text").map(texts) == [
|
||||
'-30', '-25', '-20', '-15', '-10', '-5',
|
||||
'0', '5', '10', '15', '20', '25', '30']
|
||||
assert q(".axis.y text").map(texts) == [
|
||||
'-1.2', '-1', '-0.8', '-0.6', '-0.4', '-0.2',
|
||||
'0', '0.2', '0.4', '0.6', '0.8', '1', '1.2']
|
||||
assert q(".title").text() == 'cos sin and cos - sin'
|
||||
assert q(".legend text").map(texts) == ['test1', 'test2', 'test3']
|
||||
|
||||
|
||||
def test_line():
|
||||
"""Another simple line test"""
|
||||
line = Line()
|
||||
rng = [8, 12, 23, 73, 39, 57]
|
||||
line.add('Single serie', rng)
|
||||
line.title = "One serie"
|
||||
q = line.render_pyquery()
|
||||
assert len(q(".axis.x")) == 0
|
||||
assert len(q(".axis.y")) == 1
|
||||
assert len(q(".plot .series path")) == 1
|
||||
assert len(q(".x.axis .guides")) == 0
|
||||
assert len(q(".y.axis .guides")) == 7
|
||||
|
||||
|
||||
def test_one_dot():
|
||||
"""Line test with an unique value"""
|
||||
line = Line()
|
||||
line.add('one dot', [12])
|
||||
line.x_labels = ['one']
|
||||
q = line.render_pyquery()
|
||||
assert len(q(".axis.x")) == 1
|
||||
assert len(q(".axis.y")) == 1
|
||||
assert len(q(".y.axis .guides")) == 1
|
||||
|
||||
|
||||
def test_no_dot():
|
||||
"""Line test with an empty serie"""
|
||||
line = Line()
|
||||
line.add('no dot', [])
|
||||
q = line.render_pyquery()
|
||||
assert q(".text-overlay text").text() == 'No data'
|
||||
|
||||
|
||||
def test_no_dot_at_all():
|
||||
"""Line test with no value"""
|
||||
q = Line().render_pyquery()
|
||||
assert q(".text-overlay text").text() == 'No data'
|
||||
|
||||
|
||||
def test_not_equal_x_labels():
|
||||
"""Test x_labels"""
|
||||
line = Line()
|
||||
line.add('test1', range(100))
|
||||
line.truncate_label = -1
|
||||
line.x_labels = map(str, range(11))
|
||||
q = line.render_pyquery()
|
||||
assert len(q(".dots")) == 100
|
||||
assert len(q(".axis.x")) == 1
|
||||
assert q(".axis.x text").map(texts) == [
|
||||
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '10']
|
||||
|
||||
|
||||
def test_int_x_labels():
|
||||
"""Test x_labels"""
|
||||
line = Line()
|
||||
line.add('test1', range(100))
|
||||
line.truncate_label = -1
|
||||
line.x_labels = list(range(11))
|
||||
q = line.render_pyquery()
|
||||
assert len(q(".dots")) == 100
|
||||
assert len(q(".axis.x")) == 1
|
||||
assert q(".axis.x text").map(texts) == [
|
||||
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '10']
|
||||
|
||||
|
||||
def test_only_major_dots_every():
|
||||
"""Test major dots"""
|
||||
line = Line(show_only_major_dots=True, x_labels_major_every=3)
|
||||
line.add('test', range(12))
|
||||
line.x_labels = map(str, range(12))
|
||||
q = line.render_pyquery()
|
||||
assert len(q(".dots")) == 4
|
||||
|
||||
|
||||
def test_only_major_dots_no_labels():
|
||||
"""Test major dots with no labels"""
|
||||
line = Line(show_only_major_dots=True)
|
||||
line.add('test', range(12))
|
||||
q = line.render_pyquery()
|
||||
assert len(q(".dots")) == 12
|
||||
|
||||
|
||||
def test_only_major_dots_count():
|
||||
"""Test major dots with a major label count"""
|
||||
line = Line(show_only_major_dots=True)
|
||||
line.add('test', range(12))
|
||||
line.x_labels = map(str, range(12))
|
||||
line.x_labels_major_count = 2
|
||||
q = line.render_pyquery()
|
||||
assert len(q(".dots")) == 2
|
||||
|
||||
|
||||
def test_only_major_dots():
|
||||
"""Test major dots with specified major labels"""
|
||||
line = Line(show_only_major_dots=True,)
|
||||
line.add('test', range(12))
|
||||
line.x_labels = map(str, range(12))
|
||||
line.x_labels_major = ['1', '5', '11']
|
||||
q = line.render_pyquery()
|
||||
assert len(q(".dots")) == 3
|
||||
|
||||
|
||||
def test_line_secondary():
|
||||
"""Test line with a secondary serie"""
|
||||
line = Line()
|
||||
rng = [8, 12, 23, 73, 39, 57]
|
||||
line.add('First serie', rng)
|
||||
line.add('Secondary serie',
|
||||
map(lambda x: x * 2, rng),
|
||||
secondary=True)
|
||||
line.title = "One serie"
|
||||
q = line.render_pyquery()
|
||||
assert len(q(".axis.x")) == 0
|
||||
assert len(q(".axis.y")) == 1
|
||||
assert len(q(".plot .series path")) == 2
|
||||
assert len(q(".x.axis .guides")) == 0
|
||||
assert len(q(".y.axis .guides")) == 7
|
Reference in New Issue
Block a user