As far as I can tell, when a script is run outside of Magento, observers are not invoked when an event is fired. Why? How do I fix it?
Below is the original issue th
My first guess would be the event you're trying to hook into is a or event, because it looks like only events fire when you run a command line script.
Magento has this concept called "areas". Areas are sort-of like individual applications that live in the system (but not quite, I'm still a little fuzzy on the concept).When you setup a config.xml with your observers, you're either placing them in a tag, a tag, or a tag.
When it comes to events, Magento only loads up areas that it has to deal with for a particualr request. So, the area always gets loaded. However, the or areas only get loaded up if the application gets to the controller dispatch. Specifcally, in the following file/line
File: app/code/core/Mage/Core/Controller/Varien/Action.php
Mage::app()->loadArea($this->getLayout()->getArea());
That never happens with a command line application. Only the area gets loaded.
So, as mentioned in the first paragraph, my guess is your observer isn't firing because Magento never loads the area of the application. As for solutions, you could try moving your observer to the area. You could also try manually calling
Mage::app()->loadArea(Mage_Core_Model_App_Area::AREA_FRONTEND);
although, you'd be loading ALL observers in the area, many of which have probably been created assuming a web browser context.
If none of that helps, take a look at the dispatchEvent method on the Mage_Core_Model_App class. That's where event observers get called.