def generate_config():
    """
    Uses a current configuration if possible otherwise creates a new
    configuration for the specified job type.

    :Returns:
        - An instance of the :class:`batchapps.Configuration`.
    """

    try:
        cfg = Configuration(log_level="info", job_type="ImageMagick")
        print("Existing config found.")
        return cfg

    except InvalidConfigException as exp:
        print("Invalid Configuration: {0}\n" "Attempting to create new config.".format(exp))

    try:
        cfg = Configuration(log_level="info")

        cfg.aad_config(account=ACCOUNT_ID, key=ACCOUNT_KEY, ENDPOINT=endpoint, unattended=True)

        cfg.add_jobtype("ImageMagick")
        cfg.current_jobtype("ImageMagick")
        cfg.set("width", "500")
        cfg.set("height", "500")
        cfg.set_default_jobtype()

    except InvalidConfigException as exp:
        raise RuntimeError("Invalid Configuration: {0}".format(exp))

    finally:
        cfg.save_config()
        return cfg
Exemplo n.º 2
0
    def _configure_addon(self):
        """
        Configures the addon based on the current User Preferences
        and the supplied Batch Apps ini file configuration.

        :Returns:
            - A :class:`.batchapps.Configuration` object.
        """
        cfg = None
        try:
            data_dir = os.path.split(self.props.data_dir)

            cfg = Configuration(jobtype='Blender',
                                data_path=data_dir[0],
                                log_level=int(self.props.log_level),
                                name=self.props.ini_file,
                                datadir=data_dir[1])

        except (InvalidConfigException, IndexError) as exp:
            self.log.warning("Warning failed to load config file, "
                             "creating new default config.")
            self.log.warning(str(exp))

        finally:

            if not os.path.isdir(self.props.data_dir):
                raise EnvironmentError(
                    "Data directory not created - "
                    "please ensure you have adequate permissions.")

            if not cfg:
                cfg = Configuration(jobtype='Blender', log_level='warning')

            if self.props.endpoint:
                cfg = override_config(cfg, endpoint=self.props.endpoint)
            if self.props.account:
                cfg = override_config(cfg, account=self.props.account)
            if self.props.key:
                cfg = override_config(cfg, key=self.props.key)
            if self.props.client_id:
                cfg = override_config(cfg, client_id=self.props.client_id)
            if self.props.tenant:
                cfg = override_config(cfg, tenant=self.props.tenant)
            if self.props.redirect:
                cfg = override_config(cfg, redirect=self.props.redirect)

            cfg.save_config()
            return cfg
    def _configure_addon(self):
        """
        Configures the addon based on the current User Preferences
        and the supplied Batch Apps ini file configuration.

        :Returns:
            - A :class:`.batchapps.Configuration` object.
        """
        cfg = None
        try:
            data_dir = os.path.split(self.props.data_dir)

            cfg = Configuration(jobtype='Blender', 
                                data_path=data_dir[0],
                                log_level=int(self.props.log_level),
                                name=self.props.ini_file,
                                datadir=data_dir[1])
            
        except (InvalidConfigException, IndexError) as exp:
            self.log.warning("Warning failed to load config file, "
                             "creating new default config.")
            self.log.warning(str(exp))
            
        finally:

            if not os.path.isdir(self.props.data_dir):
                raise EnvironmentError("Data directory not created - "
                                       "please ensure you have adequate permissions.")

            if not cfg:
                cfg = Configuration(jobtype='Blender', log_level='warning')

            if self.props.endpoint:
                cfg = override_config(cfg, endpoint=self.props.endpoint)
            if self.props.account:
                cfg = override_config(cfg, account=self.props.account)
            if self.props.key:
                cfg = override_config(cfg, key=self.props.key)
            if self.props.client_id:
                cfg = override_config(cfg, client_id=self.props.client_id)
            if self.props.tenant:
                cfg = override_config(cfg, tenant=self.props.tenant)
            if self.props.redirect:
                cfg = override_config(cfg, redirect=self.props.redirect)

            cfg.save_config()
            return cfg
def create_config():
    """
    Looks for configuration settings for specified application, otherwise
    creates new configuration, sets chosen log_level.
    
    :Returns:
        - a :class:`.Configuration` instance object
    """

    global LOG_LEVEL

    if input("Run in debug mode? (yes/no)")[0].lower() == 'n':
        LOG_LEVEL = "info"

    try:
        # Look for application in existing config file
        config = Configuration(log_level=LOG_LEVEL, jobtype="MyApp")
        print("Config found.")
        return config

    except InvalidConfigException:
        print("Valid config not found. Attempting to create new config.")

    try:  
        config = Configuration(log_level=LOG_LEVEL)
        config.aad_config(endpoint=ENDPOINT,
                          account=ACCOUNT_ID,
                          key=ACCOUNT_KEY,
                          unattended=True)

        config.add_jobtype("MyApp")
        config.current_jobtype("MyApp")
        
        # Examples of default config settings for your job
        config.set("width", "500")
        config.set("height", "500")

        # Set MyApp to be the default job type
        config.set_default_jobtype()

    except InvalidConfigException as e:
         raise RuntimeError("Invalid Configuration: {0}".format(e))

    finally:
        config.save_config()
        return config
def create_config():
    """
    Looks for configuration settings for specified application, otherwise
    creates new configuration, sets chosen log_level.
    
    :Returns:
        - a :class:`.Configuration` instance object
    """

    global LOG_LEVEL

    if input("Run in debug mode? (yes/no)")[0].lower() == 'n':
        LOG_LEVEL = "info"

    try:
        # Look for application in existing config file
        config = Configuration(log_level=LOG_LEVEL, jobtype="MyApp")
        print("Config found.")
        return config

    except InvalidConfigException:
        print("Valid config not found. Attempting to create new config.")

    try:
        config = Configuration(log_level=LOG_LEVEL)
        config.aad_config(endpoint=ENDPOINT,
                          account=ACCOUNT_ID,
                          key=ACCOUNT_KEY,
                          unattended=True)

        config.add_jobtype("MyApp")
        config.current_jobtype("MyApp")

        # Examples of default config settings for your job
        config.set("width", "500")
        config.set("height", "500")

        # Set MyApp to be the default job type
        config.set_default_jobtype()

    except InvalidConfigException as e:
        raise RuntimeError("Invalid Configuration: {0}".format(e))

    finally:
        config.save_config()
        return config
Exemplo n.º 6
0
    def test_config_save_config(self, mock_open):
        """Test save_config"""

        _cfg = configparser.RawConfigParser()
        cfg = mock.create_autospec(Configuration)
        cfg._config = _cfg
        cfg._write_file = False
        cfg._cfg_file = "my_file.ini"
        cfg._log = logging.getLogger("save_config")
        save = Configuration.save_config(cfg)
        self.assertFalse(save)

        cfg._write_file = True
        save = Configuration.save_config(cfg)
        mock_open.assert_called_with("my_file.ini", 'w')
        self.assertTrue(save)

        mock_open.side_effect = OSError("test")
        save = Configuration.save_config(cfg)
        self.assertFalse(save)
    def test_config_save_config(self, mock_open):
        """Test save_config"""

        _cfg = configparser.RawConfigParser()
        cfg = mock.create_autospec(Configuration)
        cfg._config = _cfg
        cfg._write_file = False
        cfg._cfg_file = "my_file.ini"
        cfg._log = logging.getLogger("save_config")
        save = Configuration.save_config(cfg)
        self.assertFalse(save)

        cfg._write_file = True
        save = Configuration.save_config(cfg)
        mock_open.assert_called_with("my_file.ini", 'w')
        self.assertTrue(save)

        mock_open.side_effect = OSError("test")
        save = Configuration.save_config(cfg)
        self.assertFalse(save)
def generate_config():
    """
    Uses a current configuration if possible otherwise creates a new
    configuration for the specified job type.

    :Returns:
        - An instance of the :class:`batchapps.Configuration`.
    """

    try:
        cfg = Configuration(log_level="info", job_type="ImageMagick")
        print("Existing config found.")
        return cfg

    except InvalidConfigException as exp:
        print("Invalid Configuration: {0}\n"
              "Attempting to create new config.".format(exp))

    try:
        cfg = Configuration(log_level="info")

        cfg.aad_config(account=ACCOUNT_ID,
                       key=ACCOUNT_KEY,
                       ENDPOINT=endpoint,
                       unattended=True)

        cfg.add_jobtype("ImageMagick")
        cfg.current_jobtype("ImageMagick")
        cfg.set("width", "500")
        cfg.set("height", "500")
        cfg.set_default_jobtype()

    except InvalidConfigException as exp:
        raise RuntimeError("Invalid Configuration: {0}".format(exp))

    finally:
        cfg.save_config()
        return cfg