]> git.mxchange.org Git - hub.git/blobdiff - application/hub/main/producer/cruncher/work_units/class_CruncherTestUnitProducer.php
Copyright notice updated
[hub.git] / application / hub / main / producer / cruncher / work_units / class_CruncherTestUnitProducer.php
index 02d7052ef89745cdf27542a49ad5ab375c86033f..b0ca550afddd0d6e4a7f476c0cabd6bd529e2fa4 100644 (file)
@@ -4,7 +4,7 @@
  *
  * @author             Roland Haeder <webmaster@ship-simu.org>
  * @version            0.0.0
- * @copyright  Copyright (c) 2007, 2008 Roland Haeder, 2009 - 2011 Hub Developer Team
+ * @copyright  Copyright (c) 2007, 2008 Roland Haeder, 2009 - 2012 Hub Developer Team
  * @license            GNU GPL 3.0 or any newer version
  * @link               http://www.ship-simu.org
  *
@@ -41,11 +41,11 @@ class CruncherTestUnitProducer extends BaseUnitProducer implements UnitProducer,
                // Get new instance
                $producerInstance = new CruncherTestUnitProducer();
 
-               // Test units have a 'test' source
-               $sourceInstance = UnitSourceFactory::createUnitSourceInstance('test');
+               // Test units have a helper class that wraps the source
+               $helperInstance = ObjectFactory::createObjectByConfiguredName('crypto_random_message_helper_class', array('test'));
 
                // So set it in the producer
-               $producerInstance->setSourceInstance($sourceInstance);
+               $producerInstance->setHelperInstance($helperInstance);
 
                // Return the prepared instance
                return $producerInstance;
@@ -72,12 +72,13 @@ class CruncherTestUnitProducer extends BaseUnitProducer implements UnitProducer,
        }
 
        /**
-        * Produces some test units and pushes them onto the queue
+        * Prepares the produces of some test units and pushes them onto the queue
         *
+        * @param       $stateInstance  An instance of a Stateable instance
         * @return      void
-        * @todo        ~30% done
+        * @todo        ~60% done
         */
-       public function produceUnits () {
+       public function prepareUnitProduction (Stateable $stateInstance) {
                // First get a database wrapper because we want to permanently store test units
                $wrapperInstance = ObjectFactory::createObjectByConfiguredName('cruncher_unit_db_wrapper_class');
 
@@ -87,7 +88,7 @@ class CruncherTestUnitProducer extends BaseUnitProducer implements UnitProducer,
                // Add criteria for looking up already created and available test units
                $searchInstance->addCriteria(CruncherUnitDatabaseWrapper::DB_COLUMN_UNIT_TYPE  , BaseUnitProducer::UNIT_TYPE_TEST_UNIT);
                $searchInstance->addCriteria(CruncherUnitDatabaseWrapper::DB_COLUMN_UNIT_STATUS, BaseUnitProducer::UNIT_STATUS_AVAILABLE);
-               $searchInstance->setLimit($this->getConfigInstance()->getConfigEntry('cruncher_test_unit_max_count'));
+               $searchInstance->setConfiguredLimit('cruncher_test_unit_max_count');
 
                // Search for our units
                $resultInstance = $wrapperInstance->doSelectByCriteria($searchInstance);
@@ -97,9 +98,21 @@ class CruncherTestUnitProducer extends BaseUnitProducer implements UnitProducer,
                        // Entries found
                        // @TODO Unfinished work here
                        $this->debugInstance();
+
+                       // The state must be changed because ...
+                       $stateInstance->someFooStateChange();
                } else {
                        // Get an encrypted, random message from our source
-                       $encryptedMessage = $this->getSourceInstance()->generateMessageFromSource();
+                       $encryptedMessage = $this->getHelperInstance()->generateRandomMessage();
+
+                       // Debug message
+                       $this->debugOutput('PRODUCER: An encrypted, random message has been generated. Generating keys ...');
+
+                       // Set the encrypted message in the template instance
+                       $this->getTemplateInstance()->assignVariable('encrypted_message', $encryptedMessage);
+
+                       // The state must be changed because we have a new message
+                       $stateInstance->encryptedMessageGenerated();
                }
        }
 }