Source code for pyleecan.Tests.GUI.DMachineSetup.test_PWSlot21

# -*- coding: utf-8 -*-

import sys
from unittest import TestCase

from PyQt5 import QtWidgets
from PyQt5.QtTest import QTest

from ....Classes.LamSlotWind import LamSlotWind
from ....Classes.SlotW21 import SlotW21
from ....GUI.Dialog.DMachineSetup.SWSlot.PWSlot21.PWSlot21 import PWSlot21


[docs]class test_PWSlot21(TestCase): """Test that the widget PWSlot21 behave like it should"""
[docs] def setUp(self): """Run at the begining of every test to setup the gui""" self.test_obj = LamSlotWind(Rint=0.1, Rext=0.2) self.test_obj.slot = SlotW21( H0=0.10, H1=0.11, H2=0.12, W0=0.13, W1=0.14, W2=0.15, H1_is_rad=False ) self.widget = PWSlot21(self.test_obj)
[docs] @classmethod def setUpClass(cls): """Start the app for the test""" print("\nStart Test PWSlot21") cls.app = QtWidgets.QApplication(sys.argv)
[docs] @classmethod def tearDownClass(cls): """Exit the app after the test""" cls.app.quit()
[docs] def test_init(self): """Check that the Widget spinbox initialise to the lamination value""" self.assertEqual(self.widget.lf_H0.value(), 0.10) self.assertEqual(self.widget.lf_H1.value(), 0.11) self.assertEqual(self.widget.lf_H2.value(), 0.12) self.assertEqual(self.widget.lf_W0.value(), 0.13) self.assertEqual(self.widget.lf_W1.value(), 0.14) self.assertEqual(self.widget.lf_W2.value(), 0.15) # Index 0 is m self.assertEqual(self.widget.c_H1_unit.currentIndex(), 0) self.test_obj.slot = SlotW21( H0=0.20, H1=0.21, H2=0.22, W0=0.23, W1=0.24, W2=0.25, H1_is_rad=True ) self.widget = PWSlot21(self.test_obj) self.assertEqual(self.widget.lf_H0.value(), 0.20) self.assertEqual(self.widget.lf_H1.value(), 0.21) self.assertEqual(self.widget.lf_H2.value(), 0.22) self.assertEqual(self.widget.lf_W0.value(), 0.23) self.assertEqual(self.widget.lf_W1.value(), 0.24) self.assertEqual(self.widget.lf_W2.value(), 0.25) # Index 1 is rad self.assertEqual(self.widget.c_H1_unit.currentIndex(), 1)
[docs] def test_set_W0(self): """Check that the Widget allow to update W0""" self.widget.lf_W0.clear() # Clear the field before writing QTest.keyClicks(self.widget.lf_W0, "0.31") self.widget.lf_W0.editingFinished.emit() # To trigger the slot self.assertEqual(self.widget.slot.W0, 0.31) self.assertEqual(self.test_obj.slot.W0, 0.31)
[docs] def test_set_W1(self): """Check that the Widget allow to update W1""" self.widget.lf_W1.clear() QTest.keyClicks(self.widget.lf_W1, "0.32") self.widget.lf_W1.editingFinished.emit() # To trigger the slot self.assertEqual(self.widget.slot.W1, 0.32) self.assertEqual(self.test_obj.slot.W1, 0.32)
[docs] def test_set_W2(self): """Check that the Widget allow to update W2""" self.widget.lf_W2.clear() QTest.keyClicks(self.widget.lf_W2, "0.33") self.widget.lf_W2.editingFinished.emit() # To trigger the slot self.assertEqual(self.widget.slot.W2, 0.33) self.assertEqual(self.test_obj.slot.W2, 0.33)
[docs] def test_set_H0(self): """Check that the Widget allow to update H0""" self.widget.lf_H0.clear() QTest.keyClicks(self.widget.lf_H0, "0.34") self.widget.lf_H0.editingFinished.emit() # To trigger the slot self.assertEqual(self.widget.slot.H0, 0.34) self.assertEqual(self.test_obj.slot.H0, 0.34)
[docs] def test_set_H1(self): """Check that the Widget allow to update H1""" self.widget.lf_H1.clear() QTest.keyClicks(self.widget.lf_H1, "0.35") self.widget.lf_H1.editingFinished.emit() # To trigger the slot self.assertEqual(self.widget.slot.H1, 0.35) self.assertEqual(self.test_obj.slot.H1, 0.35)
[docs] def test_set_H1_is_rad(self): """Check that the Widget allow to update H1_is_rad""" self.assertTrue(not self.test_obj.slot.H1_is_rad) self.widget.c_H1_unit.setCurrentIndex(1) # Index 1 is rad self.assertTrue(self.test_obj.slot.H1_is_rad)
[docs] def test_set_H2(self): """Check that the Widget allow to update H2""" self.widget.lf_H2.clear() QTest.keyClicks(self.widget.lf_H2, "0.36") self.widget.lf_H2.editingFinished.emit() # To trigger the slot self.assertEqual(self.widget.slot.H2, 0.36) self.assertEqual(self.test_obj.slot.H2, 0.36)
[docs] def test_output_txt(self): """Check that the Output text is computed and correct """ self.test_obj = LamSlotWind( Rint=0.2, Rext=0.5, is_internal=True, is_stator=False, L1=0.85, Nrvd=3, Wrvd=0.05, ) self.test_obj.slot = SlotW21( Zs=6, W0=40e-3, W1=60e-3, W2=40e-3, H0=20e-3, H1=0, H2=130e-3, H1_is_rad=False, ) self.widget = PWSlot21(self.test_obj) self.assertEqual( self.widget.w_out.out_slot_height.text(), "Slot height: 0.1504 m" )