Salome HOME
4c4e961e374980bbcc6d3fb983ed18f736cbccf5
[modules/smesh.git] / src / Tools / blocFissure / CasTests / execution_Cas.py
1 # -*- coding: utf-8 -*-
2 # Copyright (C) 2014-2020  EDF R&D
3 #
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License, or (at your option) any later version.
8 #
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12 # Lesser General Public License for more details.
13 #
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
17 #
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19 #
20
21 import sys, traceback
22 import logging
23 from blocFissure import gmu
24 from blocFissure.gmu import initLog
25
26 # -----------------------------------------------------------------------------------------------
27 #initLog.setDebug()
28 #initLog.setVerbose()
29 #initLog.setRelease()
30 #initLog.setPerfTests()
31
32 # ---tous les cas en séquence, ou les cas sélectionnés ...
33 runall = True
34 if runall:
35   torun = [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]
36 else: #prob 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27
37   torun = [ 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1] # pb
38   torun = [ 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 0] # OK
39 # -----------------------------------------------------------------------------------------------
40
41 from blocFissure.gmu import geomsmesh
42 from blocFissure.gmu.casStandard import casStandard
43
44 problemes = list()
45
46 n_cas = 0
47 from blocFissure.CasTests.cubeAngle import cubeAngle
48 problemes.append(cubeAngle(n_cas))
49
50 n_cas += 1
51 from blocFissure.CasTests.cubeAngle2 import cubeAngle2
52 problemes.append(cubeAngle2(n_cas))
53
54 n_cas += 1
55 from blocFissure.CasTests import cubeCoin
56 problemes.append(casStandard(cubeCoin.dicoParams, cubeCoin.referencesMaillageFissure, n_cas, "cubeCoin"))
57
58 n_cas += 1
59 from blocFissure.CasTests import cubeMilieu
60 problemes.append(casStandard(cubeMilieu.dicoParams, cubeMilieu.referencesMaillageFissure, n_cas, "cubeMilieu"))
61
62 n_cas += 1
63 from blocFissure.CasTests import cubeTransverse
64 problemes.append(casStandard(cubeTransverse.dicoParams, cubeTransverse.referencesMaillageFissure, n_cas, "cubeTransverse"))
65
66 n_cas += 1
67 from blocFissure.CasTests.cylindre import cylindre
68 problemes.append(cylindre(n_cas))
69
70 n_cas += 1
71 from blocFissure.CasTests.cylindre_2 import cylindre_2
72 problemes.append(cylindre_2(n_cas))
73
74 n_cas += 1
75 from blocFissure.CasTests import disquePerce
76 problemes.append(casStandard(disquePerce.dicoParams, disquePerce.referencesMaillageFissure, n_cas, "disquePerce"))
77
78 n_cas += 1
79 from blocFissure.CasTests.ellipse_1 import ellipse_1
80 problemes.append(ellipse_1(n_cas))
81
82 n_cas += 1
83 from blocFissure.CasTests.ellipse_2 import ellipse_2
84 problemes.append(ellipse_2(n_cas))
85
86 n_cas += 1
87 from blocFissure.CasTests.eprouvetteCourbe import eprouvetteCourbe
88 problemes.append(eprouvetteCourbe(n_cas))
89
90 n_cas += 1
91 from blocFissure.CasTests.eprouvetteDroite import eprouvetteDroite
92 problemes.append(eprouvetteDroite(n_cas))
93
94 n_cas += 1
95 from blocFissure.CasTests.eprouvetteDroite_2 import eprouvetteDroite_2
96 problemes.append(eprouvetteDroite_2(n_cas))
97
98 n_cas += 1
99 from blocFissure.CasTests.faceGauche import faceGauche
100 problemes.append(faceGauche(n_cas))
101
102 n_cas += 1
103 from blocFissure.CasTests.faceGauche_2 import faceGauche_2
104 problemes.append(faceGauche_2(n_cas))
105
106 n_cas += 1
107 from blocFissure.CasTests.fissureCoude_1 import fissureCoude_1
108 problemes.append(fissureCoude_1(n_cas))
109
110 n_cas += 1
111 from blocFissure.CasTests.fissureCoude_10 import fissureCoude_10
112 problemes.append(fissureCoude_10(n_cas))
113
114 n_cas += 1
115 from blocFissure.CasTests.fissureCoude_2 import fissureCoude_2
116 problemes.append(fissureCoude_2(n_cas))
117
118 n_cas += 1
119 from blocFissure.CasTests.fissureCoude_3 import fissureCoude_3
120 problemes.append(fissureCoude_3(n_cas))
121
122 n_cas += 1
123 from blocFissure.CasTests.fissureCoude_4 import fissureCoude_4
124 problemes.append(fissureCoude_4(n_cas))
125
126 n_cas += 1
127 from blocFissure.CasTests.fissureCoude_5 import fissureCoude_5
128 problemes.append(fissureCoude_5(n_cas))
129
130 n_cas += 1
131 from blocFissure.CasTests.fissureCoude_6 import fissureCoude_6
132 problemes.append(fissureCoude_6(n_cas))
133
134 n_cas += 1
135 from blocFissure.CasTests.fissureCoude_7 import fissureCoude_7
136 problemes.append(fissureCoude_7(n_cas))
137
138 n_cas += 1
139 from blocFissure.CasTests.fissureCoude_8 import fissureCoude_8
140 problemes.append(fissureCoude_8(n_cas))
141
142 n_cas += 1
143 from blocFissure.CasTests.fissureCoude_9 import fissureCoude_9
144 problemes.append(fissureCoude_9(n_cas))
145
146 n_cas += 1
147 from blocFissure.CasTests.fissure_Coude import fissure_Coude
148 problemes.append(fissure_Coude(n_cas))
149
150 n_cas += 1
151 from blocFissure.CasTests.fissure_Coude_4 import fissure_Coude_4
152 problemes.append(fissure_Coude_4(n_cas))
153
154 n_cas += 1
155 from blocFissure.CasTests.vis_1 import vis_1
156 problemes.append(vis_1(n_cas))
157
158 #=============================================================
159 while True:
160
161   if ( len(problemes) != len(torun) ):
162     texte  = "\nNombre de problèmes définis  : {}\n".format(len(problemes))
163     texte += "Longueur de la liste 'torun' : {}\n".format(len(torun))
164     texte += "\t==> Incohérence de programmation à corriger."
165     print (texte)
166     break
167
168   ligne = "---------------------------------------------------------------------"
169   texte = ""
170   for iaux, cas in enumerate(problemes):
171     #print ("Cas n° {}, '{}'".format(iaux,cas.nomProbleme))
172     if torun[iaux]:
173       texte_a = "\n=== Exécution du cas n° {}, '{}'".format(iaux,cas.nomProbleme)
174       logging.critical(ligne+texte_a)
175       try:
176         cas.executeProbleme()
177       except:
178         traceback.print_exc()
179         texte += "Problème avec le cas n° {}, '{}'\n".format(iaux,cas.nomProbleme)
180       print(ligne)
181
182   if not texte:
183     texte = "Tous les tests se sont bien passés.\n"
184   print (texte+ligne)
185
186   break
187