コード例 #1
0
ファイル: test.py プロジェクト: antonpaquin/hydrus
 def __init__( self ):
     
     self.db_dir = tempfile.mkdtemp()
     
     TestConstants.DB_DIR = self.db_dir
     
     self._server_files_dir = os.path.join( self.db_dir, 'server_files' )
     self._updates_dir = os.path.join( self.db_dir, 'test_updates' )
     
     client_files_default = os.path.join( self.db_dir, 'client_files' )
     
     HydrusPaths.MakeSureDirectoryExists( self._server_files_dir )
     HydrusPaths.MakeSureDirectoryExists( self._updates_dir )
     HydrusPaths.MakeSureDirectoryExists( client_files_default )
     
     HG.controller = self
     HG.client_controller = self
     HG.server_controller = self
     HG.test_controller = self
     
     self.gui = self
     
     self._call_to_threads = []
     
     self._pubsub = HydrusPubSub.HydrusPubSub( self )
     
     self.new_options = ClientOptions.ClientOptions( self.db_dir )
     
     HC.options = ClientDefaults.GetClientDefaultOptions()
     
     self.options = HC.options
     
     def show_text( text ): pass
     
     HydrusData.ShowText = show_text
     
     self._reads = {}
     
     self._reads[ 'hydrus_sessions' ] = []
     self._reads[ 'local_booru_share_keys' ] = []
     self._reads[ 'messaging_sessions' ] = []
     self._reads[ 'tag_censorship' ] = []
     self._reads[ 'options' ] = ClientDefaults.GetClientDefaultOptions()
     self._reads[ 'file_system_predicates' ] = []
     self._reads[ 'media_results' ] = []
     
     self.example_tag_repo_service_key = HydrusData.GenerateKey()
     
     services = []
     
     services.append( ClientServices.GenerateService( CC.LOCAL_BOORU_SERVICE_KEY, HC.LOCAL_BOORU, CC.LOCAL_BOORU_SERVICE_KEY ) )
     services.append( ClientServices.GenerateService( CC.COMBINED_LOCAL_FILE_SERVICE_KEY, HC.COMBINED_LOCAL_FILE, CC.COMBINED_LOCAL_FILE_SERVICE_KEY ) )
     services.append( ClientServices.GenerateService( CC.LOCAL_FILE_SERVICE_KEY, HC.LOCAL_FILE_DOMAIN, CC.LOCAL_FILE_SERVICE_KEY ) )
     services.append( ClientServices.GenerateService( CC.TRASH_SERVICE_KEY, HC.LOCAL_FILE_TRASH_DOMAIN, CC.LOCAL_FILE_SERVICE_KEY ) )
     services.append( ClientServices.GenerateService( CC.LOCAL_TAG_SERVICE_KEY, HC.LOCAL_TAG, CC.LOCAL_TAG_SERVICE_KEY ) )
     services.append( ClientServices.GenerateService( self.example_tag_repo_service_key, HC.TAG_REPOSITORY, 'example tag repo' ) )
     services.append( ClientServices.GenerateService( CC.COMBINED_TAG_SERVICE_KEY, HC.COMBINED_TAG, CC.COMBINED_TAG_SERVICE_KEY ) )
     services.append( ClientServices.GenerateService( TestConstants.LOCAL_RATING_LIKE_SERVICE_KEY, HC.LOCAL_RATING_LIKE, 'example local rating like service' ) )
     services.append( ClientServices.GenerateService( TestConstants.LOCAL_RATING_NUMERICAL_SERVICE_KEY, HC.LOCAL_RATING_NUMERICAL, 'example local rating numerical service' ) )
     
     self._reads[ 'services' ] = services
     
     client_files_locations = {}
     
     for prefix in HydrusData.IterateHexPrefixes():
         
         for c in ( 'f', 't', 'r' ):
             
             client_files_locations[ c + prefix ] = client_files_default
             
         
     
     self._reads[ 'client_files_locations' ] = client_files_locations
     
     self._reads[ 'sessions' ] = []
     self._reads[ 'tag_parents' ] = {}
     self._reads[ 'tag_siblings' ] = {}
     self._reads[ 'in_inbox' ] = False
     
     self._writes = collections.defaultdict( list )
     
     self._managers = {}
     
     self.services_manager = ClientCaches.ServicesManager( self )
     self.client_files_manager = ClientCaches.ClientFilesManager( self )
     
     self.parsing_cache = ClientCaches.ParsingCache()
     
     bandwidth_manager = ClientNetworkingBandwidth.NetworkBandwidthManager()
     session_manager = ClientNetworkingSessions.NetworkSessionManager()
     domain_manager = ClientNetworkingDomain.NetworkDomainManager()
     login_manager = ClientNetworkingLogin.NetworkLoginManager()
     
     self.network_engine = ClientNetworking.NetworkEngine( self, bandwidth_manager, session_manager, domain_manager, login_manager )
     
     self.CallToThreadLongRunning( self.network_engine.MainLoop )
     
     self._managers[ 'tag_censorship' ] = ClientCaches.TagCensorshipManager( self )
     self._managers[ 'tag_siblings' ] = ClientCaches.TagSiblingsManager( self )
     self._managers[ 'tag_parents' ] = ClientCaches.TagParentsManager( self )
     self._managers[ 'undo' ] = ClientCaches.UndoManager( self )
     self.server_session_manager = HydrusSessions.HydrusSessionManagerServer()
     
     self.local_booru_manager = ClientCaches.LocalBooruCache( self )
     
     self._cookies = {}
     
     self._job_scheduler = HydrusThreading.JobScheduler( self )
     
     self._job_scheduler.start()
コード例 #2
0
     
     if not HydrusPaths.DirectoryIsWritable( db_dir ) or HC.RUNNING_FROM_MACOS_APP:
         
         db_dir = HC.USERPATH_DB_DIR
         
     
 else:
     
     db_dir = result.db_dir
     
 
 db_dir = HydrusPaths.ConvertPortablePathToAbsPath( db_dir, HC.BASE_DIR )
 
 try:
     
     HydrusPaths.MakeSureDirectoryExists( db_dir )
     
 except:
     
     raise Exception( 'Could not ensure db path "{}" exists! Check the location is correct and that you have permission to write to it!'.format( db_dir ) )
     
 
 if not os.path.isdir( db_dir ):
     
     raise Exception( 'The given db path "{}" is not a directory!'.format( db_dir ) )
     
 
 if not HydrusPaths.DirectoryIsWritable( db_dir ):
     
     raise Exception( 'The given db path "{}" is not a writable-to!'.format( db_dir ) )
     
コード例 #3
0
ファイル: test.py プロジェクト: ipatrol/hydrus
    def __init__(self):

        self._db_dir = tempfile.mkdtemp()

        TestConstants.DB_DIR = self._db_dir

        self._server_files_dir = os.path.join(self._db_dir, 'server_files')
        self._updates_dir = os.path.join(self._db_dir, 'test_updates')

        client_files_default = os.path.join(self._db_dir, 'client_files')

        HydrusPaths.MakeSureDirectoryExists(self._server_files_dir)
        HydrusPaths.MakeSureDirectoryExists(self._updates_dir)
        HydrusPaths.MakeSureDirectoryExists(client_files_default)

        HydrusGlobals.controller = self
        HydrusGlobals.client_controller = self
        HydrusGlobals.server_controller = self
        HydrusGlobals.test_controller = self

        self._pubsub = HydrusPubSub.HydrusPubSub(self)

        self._new_options = ClientData.ClientOptions(self._db_dir)

        def show_text(text):
            pass

        HydrusData.ShowText = show_text

        self._http = ClientNetworking.HTTPConnectionManager()

        self._call_to_threads = []

        self._reads = {}

        self._reads['hydrus_sessions'] = []
        self._reads['local_booru_share_keys'] = []
        self._reads['messaging_sessions'] = []
        self._reads['tag_censorship'] = []
        self._reads['options'] = ClientDefaults.GetClientDefaultOptions()

        services = []

        services.append(
            ClientServices.GenerateService(CC.LOCAL_BOORU_SERVICE_KEY,
                                           HC.LOCAL_BOORU,
                                           CC.LOCAL_BOORU_SERVICE_KEY))
        services.append(
            ClientServices.GenerateService(CC.COMBINED_LOCAL_FILE_SERVICE_KEY,
                                           HC.COMBINED_LOCAL_FILE,
                                           CC.COMBINED_LOCAL_FILE_SERVICE_KEY))
        services.append(
            ClientServices.GenerateService(CC.LOCAL_FILE_SERVICE_KEY,
                                           HC.LOCAL_FILE_DOMAIN,
                                           CC.LOCAL_FILE_SERVICE_KEY))
        services.append(
            ClientServices.GenerateService(CC.TRASH_SERVICE_KEY,
                                           HC.LOCAL_FILE_TRASH_DOMAIN,
                                           CC.LOCAL_FILE_SERVICE_KEY))
        services.append(
            ClientServices.GenerateService(CC.LOCAL_TAG_SERVICE_KEY,
                                           HC.LOCAL_TAG,
                                           CC.LOCAL_TAG_SERVICE_KEY))

        self._reads['services'] = services

        client_files_locations = {}

        for prefix in HydrusData.IterateHexPrefixes():

            for c in ('f', 't', 'r'):

                client_files_locations[c + prefix] = client_files_default

        self._reads['client_files_locations'] = client_files_locations

        self._reads['sessions'] = []
        self._reads['tag_parents'] = {}
        self._reads['tag_siblings'] = {}
        self._reads['web_sessions'] = {}

        HC.options = ClientDefaults.GetClientDefaultOptions()

        self._writes = collections.defaultdict(list)

        self._managers = {}

        self._services_manager = ClientCaches.ServicesManager(self)
        self._client_files_manager = ClientCaches.ClientFilesManager(self)
        self._client_session_manager = ClientCaches.HydrusSessionManager(self)

        self._managers['tag_censorship'] = ClientCaches.TagCensorshipManager(
            self)
        self._managers['tag_siblings'] = ClientCaches.TagSiblingsManager(self)
        self._managers['tag_parents'] = ClientCaches.TagParentsManager(self)
        self._managers['undo'] = ClientCaches.UndoManager(self)
        self._managers['web_sessions'] = TestConstants.FakeWebSessionManager()
        self._server_session_manager = HydrusSessions.HydrusSessionManagerServer(
        )
        self._managers['local_booru'] = ClientCaches.LocalBooruCache(self)

        self._cookies = {}