예제 #1
0
void test_clone2()
{
    auto ctx = vle::utils::make_context();
    vpz::Vpz file(ctx->getTemplate("unittest.vpz").string());

    CoupledModel* oldtop = dynamic_cast < CoupledModel* >(
        file.project().model().node());
    Ensures(oldtop);

    CoupledModel* top = dynamic_cast < CoupledModel* >(oldtop->clone());
    Ensures(top);
    CoupledModel* top1(dynamic_cast < CoupledModel*
                       >(top->findModel("top1")));
    Ensures(top1);
    CoupledModel* top2(dynamic_cast < CoupledModel*
                       >(top->findModel("top2")));
    Ensures(top2);

    AtomicModel* f(dynamic_cast < AtomicModel* >(top2->findModel("f")));
    Ensures(f);
    AtomicModel* g(dynamic_cast < AtomicModel* >(top2->findModel("g")));
    Ensures(g);

    delete top;
}
예제 #2
0
파일: test8.cpp 프로젝트: Chabrier/vle
void
test_clone2()
{
    auto ctx = vle::utils::make_context();
    vpz::Vpz file(VPZ_TEST_DIR "/unittest.vpz");

    CoupledModel* oldtop =
      dynamic_cast<CoupledModel*>(file.project().model().node());
    Ensures(oldtop);

    auto top = std::unique_ptr<CoupledModel>(
      dynamic_cast<CoupledModel*>(oldtop->clone()));

    Ensures(top);
    if (not top)
        return;

    CoupledModel* top1(dynamic_cast<CoupledModel*>(top->findModel("top1")));
    Ensures(top1);
    if (not top1)
        return;

    CoupledModel* top2(dynamic_cast<CoupledModel*>(top->findModel("top2")));
    Ensures(top2);
    if (not top2)
        return;

    AtomicModel* f(dynamic_cast<AtomicModel*>(top2->findModel("f")));
    Ensures(f);
    AtomicModel* g(dynamic_cast<AtomicModel*>(top2->findModel("g")));
    Ensures(g);
}
예제 #3
0
void test_clone1()
{
    CoupledModel* top = new CoupledModel("top", nullptr);
    top->addInputPort("in");
    top->addOutputPort("out");

    AtomicModel* a(top->addAtomicModel("top"));
    a->addInputPort("in");
    a->addOutputPort("out");

    AtomicModel* b(top->addAtomicModel("b"));
    b->addInputPort("in");
    b->addOutputPort("out");

    top->addInputConnection("in", "top", "in");
    top->addInternalConnection("top", "out", "b", "in");
    top->addInternalConnection("b", "out", "top", "in");
    top->addOutputConnection("top", "out", "out");

    Ensures(top->existInternalConnection("top", "out", "b", "in"));
    Ensures(top->existInternalConnection("b", "out", "top", "in"));

    CoupledModel* newtop(dynamic_cast < CoupledModel* >(top->clone()));
    Ensures(newtop != nullptr);
    Ensures(newtop->getModelList().size() == 2);

    AtomicModel* newa = dynamic_cast < AtomicModel* >(newtop->findModel("top"));
    Ensures(newa != a);
    AtomicModel* newb = dynamic_cast < AtomicModel* >(newtop->findModel("b"));
    Ensures(newb != b);

    Ensures(newtop->existInternalConnection("top", "out", "b", "in"));
    Ensures(newtop->existInternalConnection("b", "out", "top", "in"));
    Ensures(newtop->existInputConnection("in", "top", "in"));
    Ensures(newtop->existOutputConnection("top", "out", "out"));
    newtop->delAllConnection();
    Ensures(not newtop->existOutputConnection("top", "out", "out"));
    Ensures(not newtop->existInternalConnection("top", "out", "b", "in"));
    Ensures(not newtop->existInternalConnection("top", "out", "b", "in"));
    Ensures(not newtop->existInternalConnection("b", "out", "top", "in"));
    Ensures(top->existInternalConnection("top", "out", "b", "in"));
    Ensures(top->existInternalConnection("b", "out", "top", "in"));
    Ensures(top->existInputConnection("in", "top", "in"));
    Ensures(top->existOutputConnection("top", "out", "out"));

    delete newtop;
    delete top;
}