setDescription('Setup dbs for tests environment');
    }
    protected function doExecute(InputInterface $input, OutputInterface $output)
    {
        if (!$this->container['phraseanet.configuration']->isSetup()) {
            throw new RuntimeException(sprintf(
                'Phraseanet is not setup. You can run bin/setup system::install command to install Phraseanet.'
            ));
        }
        $settings = Yaml::parse(file_get_contents(__DIR__ . '/../../../../../resources/hudson/InstallDBs.yml'));
        $dbs = array();
        $dbs[] = $settings['database']['ab_name'];
        $dbs[] = $settings['database']['db_name'];
        /** @var Connection $connection */
        $connection = $this->container['orm.em']->getConnection();
        $schema = $connection->getSchemaManager();
        foreach($dbs as $name) {
            $output->writeln('Creating database "'.$name.'"...OK');
            $name = StringHelper::SqlQuote($name, StringHelper::SQL_IDENTIFIER);    // quote as `identifier`
            $schema->dropAndCreateDatabase($name);
        }
        $user = StringHelper::SqlQuote($settings['database']['user'], StringHelper::SQL_VALUE); // quote as 'value'
        $host = StringHelper::SqlQuote($settings['database']['host'], StringHelper::SQL_VALUE);
        $pass = StringHelper::SqlQuote($settings['database']['password'], StringHelper::SQL_VALUE);
        $ab_name = StringHelper::SqlQuote($settings['database']['ab_name'], StringHelper::SQL_IDENTIFIER);
        $db_name = StringHelper::SqlQuote($settings['database']['db_name'], StringHelper::SQL_IDENTIFIER);
        $this->container['orm.em']->getConnection()->executeUpdate(
            'GRANT ALL PRIVILEGES ON '.$ab_name.'.* TO '.$user.'@'.$host.' IDENTIFIED BY '.$pass.' WITH GRANT OPTION'
        );
        $this->container['orm.em']->getConnection()->executeUpdate(
            'GRANT ALL PRIVILEGES ON '.$db_name.'.* TO '.$user.'@'.$host.' IDENTIFIED BY '.$pass.' WITH GRANT OPTION'
        );
        $this->container['orm.em']->getConnection()->executeUpdate('SET @@global.sql_mode= ""');
        return 0;
    }
}