Changeset 30438f for src/Fragmentation


Ignore:
Timestamp:
Jul 6, 2012, 10:18:42 AM (12 years ago)
Author:
Frederik Heber <heber@…>
Branches:
Action_Thermostats, Add_AtomRandomPerturbation, Add_FitFragmentPartialChargesAction, Add_RotateAroundBondAction, Add_SelectAtomByNameAction, Added_ParseSaveFragmentResults, AddingActions_SaveParseParticleParameters, Adding_Graph_to_ChangeBondActions, Adding_MD_integration_tests, Adding_ParticleName_to_Atom, Adding_StructOpt_integration_tests, AtomFragments, Automaking_mpqc_open, AutomationFragmentation_failures, Candidate_v1.5.4, Candidate_v1.6.0, Candidate_v1.6.1, ChangeBugEmailaddress, ChangingTestPorts, ChemicalSpaceEvaluator, CombiningParticlePotentialParsing, Combining_Subpackages, Debian_Package_split, Debian_package_split_molecuildergui_only, Disabling_MemDebug, Docu_Python_wait, EmpiricalPotential_contain_HomologyGraph, EmpiricalPotential_contain_HomologyGraph_documentation, Enable_parallel_make_install, Enhance_userguide, Enhanced_StructuralOptimization, Enhanced_StructuralOptimization_continued, Example_ManyWaysToTranslateAtom, Exclude_Hydrogens_annealWithBondGraph, FitPartialCharges_GlobalError, Fix_BoundInBox_CenterInBox_MoleculeActions, Fix_ChargeSampling_PBC, Fix_ChronosMutex, Fix_FitPartialCharges, Fix_FitPotential_needs_atomicnumbers, Fix_ForceAnnealing, Fix_IndependentFragmentGrids, Fix_ParseParticles, Fix_ParseParticles_split_forward_backward_Actions, Fix_PopActions, Fix_QtFragmentList_sorted_selection, Fix_Restrictedkeyset_FragmentMolecule, Fix_StatusMsg, Fix_StepWorldTime_single_argument, Fix_Verbose_Codepatterns, Fix_fitting_potentials, Fixes, ForceAnnealing_goodresults, ForceAnnealing_oldresults, ForceAnnealing_tocheck, ForceAnnealing_with_BondGraph, ForceAnnealing_with_BondGraph_continued, ForceAnnealing_with_BondGraph_continued_betteresults, ForceAnnealing_with_BondGraph_contraction-expansion, FragmentAction_writes_AtomFragments, FragmentMolecule_checks_bonddegrees, GeometryObjects, Gui_Fixes, Gui_displays_atomic_force_velocity, ImplicitCharges, IndependentFragmentGrids, IndependentFragmentGrids_IndividualZeroInstances, IndependentFragmentGrids_IntegrationTest, IndependentFragmentGrids_Sole_NN_Calculation, JobMarket_RobustOnKillsSegFaults, JobMarket_StableWorkerPool, JobMarket_unresolvable_hostname_fix, MoreRobust_FragmentAutomation, ODR_violation_mpqc_open, PartialCharges_OrthogonalSummation, PdbParser_setsAtomName, PythonUI_with_named_parameters, QtGui_reactivate_TimeChanged_changes, Recreated_GuiChecks, Rewrite_FitPartialCharges, RotateToPrincipalAxisSystem_UndoRedo, SaturateAtoms_findBestMatching, SaturateAtoms_singleDegree, StoppableMakroAction, Subpackage_CodePatterns, Subpackage_JobMarket, Subpackage_LinearAlgebra, Subpackage_levmar, Subpackage_mpqc_open, Subpackage_vmg, Switchable_LogView, ThirdParty_MPQC_rebuilt_buildsystem, TrajectoryDependenant_MaxOrder, TremoloParser_IncreasedPrecision, TremoloParser_MultipleTimesteps, TremoloParser_setsAtomName, Ubuntu_1604_changes, stable
Children:
2c5765
Parents:
7f19f8
git-author:
Frederik Heber <heber@…> (06/18/12 12:57:26)
git-committer:
Frederik Heber <heber@…> (07/06/12 10:18:42)
Message:

OperationQueue can be blocked to prevent further operations to be pushed.

  • this is used in poolworker after shutdown. E.g. when working on a job and we receive shutdown, then sendresultop might be pushed after remove op which prevents shutdown as io_service is not done.
  • added unit test function to OperationQueueUnitTest.
Location:
src/Fragmentation/Automation
Files:
5 edited

Legend:

Unmodified
Added
Removed
  • src/Fragmentation/Automation/Operations/OperationQueue.cpp

    r7f19f8 r30438f  
    4848{
    4949  if (op != NULL) {
    50     AsyncOp_ptr ptr(op); // this always prevents memory loss
    51     ptr->signOn(this);
    52     OperationQueue_t::iterator iter = queue.insert(queue.end(), ptr );
    53     op = NULL;
    54     AddressMap.insert( make_pair(*iter, address) );
    55     LaunchNextOp();
     50    if (!IsBlockedFlag) {
     51      AsyncOp_ptr ptr(op); // this always prevents memory loss
     52      ptr->signOn(this);
     53      OperationQueue_t::iterator iter = queue.insert(queue.end(), ptr );
     54      op = NULL;
     55      AddressMap.insert( make_pair(*iter, address) );
     56      LaunchNextOp();
     57    } else {
     58      ELOG(1, "Queue is currently blocked, dropping operation "+op->getName()+".");
     59      delete op;
     60      op = NULL;
     61    }
    5662  } else {
    5763    ELOG(1, "Given operation pointer is NULL.");
  • src/Fragmentation/Automation/Operations/OperationQueue.hpp

    r7f19f8 r30438f  
    3838  OperationQueue() :
    3939    Observer("OperationQueue"),
    40     RunningOps(0)
     40    RunningOps(0),
     41    IsBlockedFlag(false)
    4142  {}
    4243  /** Default destructor for class OperationQueue.
     
    6162  bool empty() const {
    6263    return queue.empty();
     64  }
     65
     66  /** Blocks the queue for any further operation.
     67   *
     68   */
     69  void block()
     70  {
     71    IsBlockedFlag = true;
     72  }
     73
     74  /** Unblocks the queue, operations may again be pushed.
     75   *
     76   */
     77  void unblock()
     78  {
     79    IsBlockedFlag = false;
     80  }
     81
     82  /** Getter whether queue is currently blocked.
     83   *
     84   * @return OperationQueue::IsBlockedFlag
     85   */
     86  bool isBlocked() const
     87  {
     88    return IsBlockedFlag;
    6389  }
    6490
     
    113139  //!> Association for each operation to its address to connect to
    114140  AddressMap_t AddressMap;
     141
     142  //!> status flag whether queue is blocked or operations may be pushed.
     143  bool IsBlockedFlag;
    115144};
    116145
  • src/Fragmentation/Automation/Pool/PoolWorker.cpp

    r7f19f8 r30438f  
    165165/** Helper function to shutdown the worker properly.
    166166 *
    167  * Note that we will use ShutdownWorkerOperation to unlist from server's pool.
    168  * We stop the io_service via its callback handler in case of success.
     167 * Note that we will use RemoveFromPoolOperation to unlist from server's pool.
    169168 */
    170169void PoolWorker::shutdown()
     
    175174  LOG(2, "DEBUG: Putting remove from pool operation into queue ...");
    176175  OpQueue.push_back(removeOp, ServerAddress);
     176  // block queue such that io_service may stop
     177  OpQueue.block();
    177178}
    178179
     
    180181 *
    181182 * This is called after we have been removed from server's pool
    182  *
     183 * We stop the io_service via its callback handler in case of success.
    183184 */
    184185void PoolWorker::finish()
  • src/Fragmentation/Automation/unittests/OperationQueueUnitTest.cpp

    r7f19f8 r30438f  
    103103}
    104104
     105/** UnitTest for block
     106 */
     107void OperationQueueTest::blockTest()
     108{
     109  // block queue
     110  queue->block();
     111  CPPUNIT_ASSERT( queue->isBlocked() );
     112  queue->push_back(op,* address);
     113  op = NULL;
     114  CPPUNIT_ASSERT_EQUAL( (size_t)0, queue->queue.size() );
     115
     116  // block deletes op, hence re-instantiate
     117  AsyncOperation *backup = // we need backup as op is NULL'ed
     118      op = new AsyncOperationStub(std::string("AsyncOperationStub"), *conn);
     119
     120  // unblock and we suceed
     121  queue->unblock();
     122  CPPUNIT_ASSERT( !queue->isBlocked() );
     123  queue->push_back(op,* address);
     124  CPPUNIT_ASSERT_EQUAL( (size_t)1, queue->queue.size() );
     125  CPPUNIT_ASSERT_EQUAL( backup, queue->queue.begin()->get() );
     126}
     127
    105128/** UnitTest for remove
    106129 */
  • src/Fragmentation/Automation/unittests/OperationQueueUnitTest.hpp

    r7f19f8 r30438f  
    3030    CPPUNIT_TEST_SUITE( OperationQueueTest) ;
    3131    CPPUNIT_TEST ( push_backTest );
     32    CPPUNIT_TEST ( blockTest );
    3233    CPPUNIT_TEST ( removeTest );
    3334    CPPUNIT_TEST ( findTest );
     
    3839      void setUp();
    3940      void tearDown();
     41      void blockTest();
    4042      void findTest();
    4143      void push_backTest();
Note: See TracChangeset for help on using the changeset viewer.