Salome HOME
replace abs by fabs for doubles
[modules/hydro.git] / src / HYDRO_tests / test_HYDROData_PolylineXY.cxx
index 7ed3645f951f5f6dcf60a0d2c97b760058ffdba4..914097681dc23b405dbba726f8e3f0806a43f7bc 100644 (file)
@@ -29,6 +29,8 @@
 #include <HYDROData_Tool.h>
 #include <HYDROGUI_Shape.h>
 #include <HYDROGUI_Polyline.h>
+#include <HYDROData_SinusX.h>
+#include <BRep_Builder.hxx>
 
 #include <AIS_DisplayMode.hxx>
 #include <AIS_PointCloud.hxx>
@@ -46,6 +48,9 @@
 #include <TopoDS_Vertex.hxx>
 #include <TopoDS_Wire.hxx>
 #include <gp_XY.hxx>
+#include <HYDROData_Tool.h>
+
+extern QString REF_DATA_PATH;
 
 void test_HYDROData_PolylineXY::test_polyline()
 {
@@ -539,3 +544,82 @@ void test_HYDROData_PolylineXY::test_split_straight_refs_634()
 
   aDoc->Close();
 }
+
+void test_HYDROData_PolylineXY::test_import_from_xyz()
+{
+  NCollection_Sequence<Handle(HYDROData_Entity)> ents;
+  Handle(HYDROData_Document) aDoc = HYDROData_Document::Document( 1 );
+  TCollection_AsciiString fname = REF_DATA_PATH.toLatin1().data();
+  fname += "/profiles1.xyz";
+
+  NCollection_Sequence<Handle(HYDROData_Entity)> importedEntities;
+  bool stat = HYDROData_Tool::importPolylineFromXYZ(QString(fname.ToCString()), aDoc, true, importedEntities);
+  CPPUNIT_ASSERT (stat);
+  Handle(HYDROData_PolylineXY) aPolyXY = Handle(HYDROData_PolylineXY)::DownCast(importedEntities.First());   
+  CPPUNIT_ASSERT_EQUAL (importedEntities.Size(), 1);
+  CPPUNIT_ASSERT (!aPolyXY.IsNull());
+  TestViewer::show( aPolyXY->GetShape(), 0, true, "Polyline_import_XY" );
+  CPPUNIT_ASSERT_IMAGES
+  importedEntities.Clear();
+
+  stat = HYDROData_Tool::importPolylineFromXYZ(QString(fname.ToCString()), aDoc, false, importedEntities);
+  CPPUNIT_ASSERT (stat);
+  CPPUNIT_ASSERT_EQUAL (importedEntities.Size(), 2);
+  Handle(HYDROData_Polyline3D) aPoly3D;
+  aPolyXY = Handle(HYDROData_PolylineXY)::DownCast(importedEntities.First());   
+  aPoly3D = Handle(HYDROData_Polyline3D)::DownCast(importedEntities.Last());
+  CPPUNIT_ASSERT (!aPolyXY.IsNull());
+  CPPUNIT_ASSERT (!aPoly3D.IsNull());
+  TestViewer::show( aPolyXY->GetShape(), 0, false, "Polyline_import_XYZ" );
+  TestViewer::show( aPoly3D->GetShape3D(), 0, false, "Polyline_import_XYZ_3D" );
+  CPPUNIT_ASSERT_IMAGES
+}
+
+
+void test_HYDROData_PolylineXY::test_import_from_sx()
+{
+  Handle(HYDROData_Document) aDoc = HYDROData_Document::Document( 1 );
+  TCollection_AsciiString fname = REF_DATA_PATH.toLatin1().data();
+  fname += "/polylines_sx.sx";
+
+  HYDROData_SinusX aSinusXImporter;
+  NCollection_Sequence<Handle(HYDROData_Entity)> importedEntities;
+  //bool stat = aSinusXImporter.Import(QString(fname.ToCString()), aDoc, importedEntities);
+  bool ParseStat = aSinusXImporter.OpenAndParse(QString(fname.ToCString()));
+  CPPUNIT_ASSERT (ParseStat);
+  aSinusXImporter.Import(aDoc, importedEntities, NULL);
+  CPPUNIT_ASSERT_EQUAL (importedEntities.Size(), 9);
+
+  Handle(HYDROData_PolylineXY) aPolyXY1 = Handle(HYDROData_PolylineXY)::DownCast(importedEntities(1));   
+  Handle(HYDROData_PolylineXY) aPolyXY2 = Handle(HYDROData_PolylineXY)::DownCast(importedEntities(4));  
+  Handle(HYDROData_PolylineXY) aPolyXY3 = Handle(HYDROData_PolylineXY)::DownCast(importedEntities(7));   
+
+  CPPUNIT_ASSERT (!aPolyXY1.IsNull());
+  CPPUNIT_ASSERT (!aPolyXY2.IsNull());
+  CPPUNIT_ASSERT (!aPolyXY3.IsNull());
+
+  aPolyXY1->Update();
+  aPolyXY2->Update();
+  aPolyXY3->Update();
+
+  CPPUNIT_ASSERT_EQUAL (aPolyXY1->GetName(), QString("AXIS"));
+  CPPUNIT_ASSERT_EQUAL (aPolyXY2->GetName(), QString("LB"));
+  CPPUNIT_ASSERT_EQUAL (aPolyXY3->GetName(), QString("RB"));
+
+  TopoDS_Shape sh1 = aPolyXY1->GetShape();
+  TopoDS_Shape sh2 = aPolyXY2->GetShape();
+  TopoDS_Shape sh3 = aPolyXY3->GetShape();
+  CPPUNIT_ASSERT (!sh1.IsNull());
+  CPPUNIT_ASSERT (!sh2.IsNull());
+  CPPUNIT_ASSERT (!sh3.IsNull());
+
+  BRep_Builder BB;
+  TopoDS_Compound cmp;
+  BB.MakeCompound(cmp);
+  BB.Add(cmp, sh1);
+  BB.Add(cmp, sh2);
+  BB.Add(cmp, sh3);
+
+  TestViewer::show( cmp, 0, true, "Polylines_import_SX" );
+  CPPUNIT_ASSERT_IMAGES
+}