Changeset 30438f for src/Fragmentation
- Timestamp:
- Jul 6, 2012, 10:18:42 AM (12 years ago)
- 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)
- Location:
- src/Fragmentation/Automation
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Fragmentation/Automation/Operations/OperationQueue.cpp
r7f19f8 r30438f 48 48 { 49 49 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 } 56 62 } else { 57 63 ELOG(1, "Given operation pointer is NULL."); -
src/Fragmentation/Automation/Operations/OperationQueue.hpp
r7f19f8 r30438f 38 38 OperationQueue() : 39 39 Observer("OperationQueue"), 40 RunningOps(0) 40 RunningOps(0), 41 IsBlockedFlag(false) 41 42 {} 42 43 /** Default destructor for class OperationQueue. … … 61 62 bool empty() const { 62 63 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; 63 89 } 64 90 … … 113 139 //!> Association for each operation to its address to connect to 114 140 AddressMap_t AddressMap; 141 142 //!> status flag whether queue is blocked or operations may be pushed. 143 bool IsBlockedFlag; 115 144 }; 116 145 -
src/Fragmentation/Automation/Pool/PoolWorker.cpp
r7f19f8 r30438f 165 165 /** Helper function to shutdown the worker properly. 166 166 * 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. 169 168 */ 170 169 void PoolWorker::shutdown() … … 175 174 LOG(2, "DEBUG: Putting remove from pool operation into queue ..."); 176 175 OpQueue.push_back(removeOp, ServerAddress); 176 // block queue such that io_service may stop 177 OpQueue.block(); 177 178 } 178 179 … … 180 181 * 181 182 * 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. 183 184 */ 184 185 void PoolWorker::finish() -
src/Fragmentation/Automation/unittests/OperationQueueUnitTest.cpp
r7f19f8 r30438f 103 103 } 104 104 105 /** UnitTest for block 106 */ 107 void 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 105 128 /** UnitTest for remove 106 129 */ -
src/Fragmentation/Automation/unittests/OperationQueueUnitTest.hpp
r7f19f8 r30438f 30 30 CPPUNIT_TEST_SUITE( OperationQueueTest) ; 31 31 CPPUNIT_TEST ( push_backTest ); 32 CPPUNIT_TEST ( blockTest ); 32 33 CPPUNIT_TEST ( removeTest ); 33 34 CPPUNIT_TEST ( findTest ); … … 38 39 void setUp(); 39 40 void tearDown(); 41 void blockTest(); 40 42 void findTest(); 41 43 void push_backTest();
Note:
See TracChangeset
for help on using the changeset viewer.