Esempio n. 1
0
  def testProcessOnWin7(self):
    """Tests the Process function on a Windows 7 Registry file."""
    test_file_entry = self._GetTestFileEntry(['NTUSER-WIN7.DAT'])
    key_path = (
        'HKEY_CURRENT_USER\\Software\\Microsoft\\Windows\\CurrentVersion\\'
        'Explorer\\UserAssist\\{CEBFF5CD-ACE2-4F4F-9178-9926F41749EA}')

    win_registry = self._GetWinRegistryFromFileEntry(test_file_entry)
    registry_key = win_registry.GetKeyByPath(key_path)

    plugin = userassist.UserAssistPlugin()
    storage_writer = self._ParseKeyWithPlugin(
        registry_key, plugin, file_entry=test_file_entry)

    self.assertEqual(storage_writer.number_of_warnings, 0)
    self.assertEqual(storage_writer.number_of_events, 61)

    events = list(storage_writer.GetEvents())

    expected_event_values = {
        'application_focus_count': 21,
        'application_focus_duration': 420000,
        'key_path': '{0:s}\\Count'.format(key_path),
        'number_of_executions': 14,
        # This should just be the plugin name, as we're invoking it directly,
        # and not through the parser.
        'parser': plugin.plugin_name,
        'timestamp': '2010-11-10 07:49:37.078068',
        'timestamp_desc': definitions.TIME_DESCRIPTION_LAST_RUN,
        'value_name': 'Microsoft.Windows.GettingStarted'}

    self.CheckEventValues(storage_writer, events[0], expected_event_values)
Esempio n. 2
0
  def testProcessOnWinXP(self):
    """Tests the Process function on a Windows XP Registry file."""
    test_file_entry = self._GetTestFileEntry(['NTUSER.DAT'])
    key_path = (
        'HKEY_CURRENT_USER\\Software\\Microsoft\\Windows\\CurrentVersion\\'
        'Explorer\\UserAssist\\{75048700-EF1F-11D0-9888-006097DEACF9}')

    win_registry = self._GetWinRegistryFromFileEntry(test_file_entry)
    registry_key = win_registry.GetKeyByPath(key_path)

    plugin = userassist.UserAssistPlugin()
    storage_writer = self._ParseKeyWithPlugin(
        registry_key, plugin, file_entry=test_file_entry)

    self.assertEqual(storage_writer.number_of_warnings, 0)
    self.assertEqual(storage_writer.number_of_events, 14)

    events = list(storage_writer.GetEvents())

    expected_event_values = {
        'key_path': '{0:s}\\Count'.format(key_path),
        'number_of_executions': 14,
        # This should just be the plugin name, as we're invoking it directly,
        # and not through the parser.
        'parser': plugin.plugin_name,
        'timestamp': '2009-08-04 15:11:22.811068',
        'timestamp_desc': definitions.TIME_DESCRIPTION_LAST_RUN,
        'value_name': 'UEME_RUNPIDL:%csidl2%\\MSN.lnk'}

    self.CheckEventValues(storage_writer, events[0], expected_event_values)
Esempio n. 3
0
    def testFilters(self):
        """Tests the FILTERS class attribute."""
        plugin = userassist.UserAssistPlugin()

        for guid in self._TEST_GUIDS:
            key_path = (
                'HKEY_CURRENT_USER\\Software\\Microsoft\\Windows\\CurrentVersion\\'
                'Explorer\\UserAssist\\{0:s}').format(guid)
            self._AssertFiltersOnKeyPath(plugin, key_path)

        self._AssertNotFiltersOnKeyPath(plugin, 'HKEY_LOCAL_MACHINE\\Bogus')
Esempio n. 4
0
    def testProcessOnWin7(self):
        """Tests the Process function on a Windows 7 Registry file."""
        test_file_entry = self._GetTestFileEntry(['NTUSER-WIN7.DAT'])
        key_path = (
            'HKEY_CURRENT_USER\\Software\\Microsoft\\Windows\\CurrentVersion\\'
            'Explorer\\UserAssist\\{CEBFF5CD-ACE2-4F4F-9178-9926F41749EA}')

        win_registry = self._GetWinRegistryFromFileEntry(test_file_entry)
        registry_key = win_registry.GetKeyByPath(key_path)

        plugin = userassist.UserAssistPlugin()
        storage_writer = self._ParseKeyWithPlugin(registry_key,
                                                  plugin,
                                                  file_entry=test_file_entry)

        self.assertEqual(storage_writer.number_of_warnings, 0)
        self.assertEqual(storage_writer.number_of_events, 61)

        events = list(storage_writer.GetEvents())

        event = events[0]

        self.CheckTimestamp(event.timestamp, '2010-11-10 07:49:37.078068')
        self.assertEqual(event.timestamp_desc,
                         definitions.TIME_DESCRIPTION_LAST_RUN)

        event_data = self._GetEventDataOfEvent(storage_writer, event)

        self.assertEqual(event_data.pathspec, test_file_entry.path_spec)
        # This should just be the plugin name, as we're invoking it directly,
        # and not through the parser.
        self.assertEqual(event_data.parser, plugin.plugin_name)

        expected_value_name = 'Microsoft.Windows.GettingStarted'
        self.assertEqual(event_data.value_name, expected_value_name)
        self.assertEqual(event_data.number_of_executions, 14)
        self.assertEqual(event_data.application_focus_count, 21)
        self.assertEqual(event_data.application_focus_duration, 420000)

        expected_message = ('[{0:s}\\Count] '
                            'UserAssist entry: 1 '
                            'Value name: {1:s} '
                            'Count: 14 '
                            'Application focus count: 21 '
                            'Application focus duration: 420000').format(
                                key_path, expected_value_name)
        expected_short_message = '{0:s} Count: 14'.format(expected_value_name)

        self._TestGetMessageStrings(event_data, expected_message,
                                    expected_short_message)
Esempio n. 5
0
    def testProcessOnWinXP(self):
        """Tests the Process function on a Windows XP Registry file."""
        test_file_entry = self._GetTestFileEntry(['NTUSER.DAT'])
        key_path = (
            'HKEY_CURRENT_USER\\Software\\Microsoft\\Windows\\CurrentVersion\\'
            'Explorer\\UserAssist\\{75048700-EF1F-11D0-9888-006097DEACF9}')

        win_registry = self._GetWinRegistryFromFileEntry(test_file_entry)
        registry_key = win_registry.GetKeyByPath(key_path)

        plugin = userassist.UserAssistPlugin()
        storage_writer = self._ParseKeyWithPlugin(registry_key,
                                                  plugin,
                                                  file_entry=test_file_entry)

        self.assertEqual(storage_writer.number_of_warnings, 0)
        self.assertEqual(storage_writer.number_of_events, 14)

        events = list(storage_writer.GetEvents())

        event = events[0]

        self.CheckTimestamp(event.timestamp, '2009-08-04 15:11:22.811068')
        self.assertEqual(event.timestamp_desc,
                         definitions.TIME_DESCRIPTION_LAST_RUN)

        event_data = self._GetEventDataOfEvent(storage_writer, event)

        self.assertEqual(event_data.pathspec, test_file_entry.path_spec)
        # This should just be the plugin name, as we're invoking it directly,
        # and not through the parser.
        self.assertEqual(event_data.parser, plugin.plugin_name)

        expected_value_name = 'UEME_RUNPIDL:%csidl2%\\MSN.lnk'
        self.assertEqual(event_data.value_name, expected_value_name)
        self.assertEqual(event_data.number_of_executions, 14)

        expected_message = ('[{0:s}\\Count] '
                            'Value name: {1:s} '
                            'Count: 14').format(key_path, expected_value_name)
        expected_short_message = '{0:s} Count: 14'.format(expected_value_name)

        self._TestGetMessageStrings(event_data, expected_message,
                                    expected_short_message)
Esempio n. 6
0
 def setUp(self):
     """Makes preparations before running an individual test."""
     self._plugin = userassist.UserAssistPlugin()
Esempio n. 7
0
 def setUp(self):
     """Sets up the needed objects used throughout the test."""
     self._plugin = userassist.UserAssistPlugin()