Esempio n. 1
0
def export_packages(request, **kwargs):
    """
    Exports packages to CSV
    """
    if request.method == 'GET' and kwargs.get('format', '') == 'csv':
        file_name = "ts-packages-%s.csv" % datetime.today().strftime(
            '%d-%m-%Y')
        packages_manager = PackagesManager()
        required_fields = [
            'package_name', 'upstream_url', 'transplatform_url',
            'release_streams', 'release_branch_mapping'
        ]
        packages = packages_manager.get_packages(pkg_params=required_fields)
        response = HttpResponse(content_type='text/csv', status=200)
        response[
            'Content-Disposition'] = 'attachment; filename="' + file_name + '"'
        writer = csv.writer(response)
        writer.writerow(
            [field.replace('_', ' ').title() for field in required_fields])
        for package in packages:
            writer.writerow([
                package.package_name, package.upstream_url,
                package.transplatform_url, ', '.join(package.release_streams),
                package.release_branch_mapping
                if package.release_branch_mapping else ''
            ])
        return response
    return HttpResponse(status=500)
Esempio n. 2
0
def refresh_package(request):
    """
    Package sync and re-build mappings
    """
    if request.is_ajax():
        post_params = request.POST.dict()
        package_manager = PackagesManager()
        task_type = post_params.get('task', '')
        if task_type == "mapBranches" and post_params.get('package'):
            if package_manager.build_branch_mapping(post_params['package']):
                context = Context(
                    {'META': request.META,
                     'package_name': post_params['package']}
                )
                template_string = """
                    {% load tag_branch_mapping from custom_tags %}
                    {% tag_branch_mapping package_name %}
                """
                return HttpResponse(Template(template_string).render(context))
        elif task_type == "syncUpstream" and post_params.get('package'):
            input_package_name = post_params['package']
            package = package_manager.get_packages([input_package_name], ['package_name', 'upstream_url']).get()
            if package:
                upstream_repo = package.upstream_url if package.upstream_url.endswith('.git') \
                    else package.upstream_url + ".git"
                upstream_sync_manager = UpstreamManager(package.package_name, upstream_repo,
                                                        'dashboard/sandbox', package.translation_file_ext)
                job_uuid = upstream_sync_manager.syncupstream_initiate_job()
                if job_uuid and upstream_sync_manager.upstream_trans_stats():
                    return HttpResponse(status=200)
        elif task_type == "syncPlatform" and post_params.get('package'):
            if package_manager.refresh_package(post_params['package']):
                return HttpResponse(status=200)
    return HttpResponse(status=500)
Esempio n. 3
0
def tag_branch_mapping(package):
    package_manager = PackagesManager()
    return_value = OrderedDict()
    try:
        package_details = package_manager.get_packages([package]).get()
    except:
        # log event, passing for now
        pass
    else:
        return_value.update(
            {'branch_mapping': package_details.release_branch_mapping,
             'mapping_lastupdated': package_details.mapping_lastupdated}
        )
    return return_value
Esempio n. 4
0
class ManagersMixin(object):
    """
    Managers Mixin
    """
    inventory_manager = InventoryManager()
    packages_manager = PackagesManager()
    jobs_log_manager = JobsLogManager()
    release_branch_manager = ReleaseBranchManager()
    graph_manager = GraphManager()

    def get_summary(self):
        """
        Application Inventory Stats
        """
        locales_set = self.inventory_manager.get_locales_set()
        summary = {}
        summary['locales_len'] = len(locales_set[0]) \
            if isinstance(locales_set, tuple) else 0
        platforms = self.inventory_manager.get_transplatform_slug_url()
        summary['platforms_len'] = len(platforms) if platforms else 0
        relstreams = self.inventory_manager.get_relstream_slug_name()
        summary['products_len'] = len(relstreams) if relstreams else 0
        relbranches = self.release_branch_manager.get_release_branches()
        summary['releases_len'] = relbranches.count() if relbranches else 0
        summary['packages_len'] = self.packages_manager.count_packages()
        jobs_count, last_ran_on, last_ran_type = \
            self.jobs_log_manager.get_joblog_stats()
        summary['jobs_len'] = jobs_count
        graph_rules = self.graph_manager.get_graph_rules(only_active=True)
        summary['graph_rules_len'] = graph_rules.count() if graph_rules else 0
        return summary
Esempio n. 5
0
class ManagersMixin(object):
    """
    Managers Mixin
    """
    inventory_manager = InventoryManager()
    packages_manager = PackagesManager()
    jobs_log_manager = JobsLogManager()
    release_branch_manager = ReleaseBranchManager()
    graph_manager = GraphManager()
Esempio n. 6
0
def tag_package_details(package_name, user):
    package_manager = PackagesManager()
    return_value = OrderedDict()
    try:
        package = package_manager.get_packages([package_name]).get()
        pkg_details = package.package_details_json
        if pkg_details and pkg_details.get('description'):
            return_value.update(
                {'package_desc': pkg_details['description']}
            )
    except:
        # log event, passing for now
        pass
    else:
        return_value.update(
            {'package': package,
             'user': user}
        )
    return return_value
Esempio n. 7
0
def schedule_job(request):
    """
    Handles job schedule AJAX POST request
    """
    message = "&nbsp;&nbsp;<span class='text-warning'>Request could not be processed.</span>"
    if request.is_ajax():
        job_type = request.POST.dict().get('job')
        if job_type == TS_JOB_TYPES[0]:
            transplatform_sync_manager = TransplatformSyncManager()
            job_uuid = transplatform_sync_manager.syncstats_initiate_job()
            if job_uuid:
                message = "&nbsp;&nbsp;<span class='glyphicon glyphicon-check' style='color:green'></span>" + \
                          "&nbsp;Job created and logged! UUID: <a href='/jobs/logs'>" + str(job_uuid) + "</a>"
                transplatform_sync_manager.sync_trans_stats()
            else:
                message = "&nbsp;&nbsp;<span class='text-danger'>Alas! Something unexpected happened.</span>"
        elif job_type == TS_JOB_TYPES[1]:
            relschedule_sync_manager = ReleaseScheduleSyncManager()
            job_uuid = relschedule_sync_manager.syncschedule_initiate_job()
            if job_uuid:
                message = "&nbsp;&nbsp;<span class='glyphicon glyphicon-check' style='color:green'></span>" + \
                          "&nbsp;Job created and logged! UUID: <a href='/jobs/logs'>" + str(job_uuid) + "</a>"
                relschedule_sync_manager.sync_release_schedule()
            else:
                message = "&nbsp;&nbsp;<span class='text-danger'>Alas! Something unexpected happened.</span>"
        elif job_type == TS_JOB_TYPES[2]:
            input_package_name = request.POST.dict().get('package')
            package_manager = PackagesManager()
            package = package_manager.get_packages([input_package_name], ['package_name', 'upstream_url']).get()
            if package:
                upstream_repo = package.upstream_url if package.upstream_url.endswith('.git') \
                    else package.upstream_url + ".git"
                upstream_sync_manager = UpstreamManager(package.package_name, upstream_repo,
                                                        'dashboard/sandbox', package.translation_file_ext)
                job_uuid = upstream_sync_manager.syncupstream_initiate_job()
                if job_uuid and upstream_sync_manager.upstream_trans_stats():
                    message = "&nbsp;&nbsp;<span class='glyphicon glyphicon-check' style='color:green'></span>" + \
                        "&nbsp;Job created and logged! UUID: <a href='/jobs/logs'>" + str(job_uuid) + "</a>"
                upstream_sync_manager.clean_workspace()
            else:
                message = "&nbsp;&nbsp;<span class='text-danger'>Alas! Something unexpected happened.</span>"
    return HttpResponse(message)
Esempio n. 8
0
class GraphManager(BaseManager):
    """
    Manage graph representations
    """

    package_manager = PackagesManager()
    branch_manager = ReleaseBranchManager()

    def get_graph_rules(self, graph_rule=None, only_active=None):
        """
        Fetch graph rules from db
        :return: resultset
        """
        filter_kwargs = {}
        if graph_rule:
            filter_kwargs.update(dict(rule_name=graph_rule))
        if only_active:
            filter_kwargs.update(dict(rule_status=True))

        rules = None
        try:
            rules = GraphRules.objects.filter(
                **filter_kwargs).order_by('rule_name')
        except:
            # log event, passing for now
            pass
        return rules

    def slugify_graph_rule_name(self, suggested_name):
        try:
            return slugify(suggested_name)
        except:
            # log even, passing for now
            return False

    def validate_package_branch_participation(self, relbranch, packages):
        """
        This validates that packages belong to relbranch or not
        :param relbranch: release branch
        :param packages: list of packages
        :return: list of packages that DO NOT belong
        """
        if not relbranch and not packages:
            return
        pkg_not_participate = []
        for package in packages:
            relbranches = PackageBranchMapping(package).release_branches
            if relbranch not in relbranches:
                pkg_not_participate.append(package)
        return pkg_not_participate

    def add_graph_rule(self, **kwargs):
        """
        Save graph rule in db
        :param kwargs: dict
        :return: boolean
        """
        if kwargs.get(
                'lang_selection') == "pick" and not kwargs.get('rule_langs'):
            relbranch_slug = kwargs.get('rule_relbranch')
            relbranch_lang_set = self.branch_manager.get_release_branches(
                relbranch=relbranch_slug, fields=['lang_set']).first()
            locales = self.branch_manager.get_langset(
                relbranch_lang_set.lang_set, fields=['locale_ids']).locale_ids
            if locales:
                kwargs['rule_langs'] = locales
            else:
                return False

        if not (kwargs['rule_name']):
            return
        try:
            kwargs.pop('lang_selection')
            kwargs['created_on'] = timezone.now()
            kwargs['rule_status'] = True
            new_rule = GraphRules(**kwargs)
            new_rule.save()
        except:
            # log event, pass for now
            # todo implement error msg handling
            return False
        else:
            return True

    def _normalize_stats(self, stats_nested_list, index_list):
        """
        Normalize stats for a locale index and picks higher value
        """
        temp_index_list = []
        temp_stat_list = []
        for index, stat in stats_nested_list:
            if index not in temp_index_list:
                temp_index_list.append(index)
                temp_stat_list.append(stat)
            else:
                last_stat = temp_stat_list.pop(len(temp_stat_list) - 1)
                temp_stat_list.append(last_stat) \
                    if last_stat > stat else temp_stat_list.append(stat)
        expected_stats_list = list(zip(temp_index_list, temp_stat_list))
        if len(index_list) > len(expected_stats_list):
            expected_stats_dict = dict(
                (k[0], k[1:]) for k in expected_stats_list)
            temp_patched_stats_list = []
            for index in index_list:
                temp_patched_stats_list.append(
                    [index, expected_stats_dict.get(index, [0.0])[0]])
            expected_stats_list = temp_patched_stats_list
        return expected_stats_list

    def _format_stats_for_default_graphs(self, locale_sequence, stats_dict,
                                         desc):
        """
        Formats stats dict for graph-ready material
        - sorting and normalization
        """
        stats_for_graphs_dict = OrderedDict()
        stats_for_graphs_dict['pkg_desc'] = desc
        stats_for_graphs_dict['ticks'] = \
            [[i, lang] for i, lang in enumerate(locale_sequence.values(), 0)]
        indexes = [index for index, lang in stats_for_graphs_dict['ticks']]

        graph_data_dict = {}
        for version, stats_lists in stats_dict.items():
            new_stats_list = []
            for stats_tuple in stats_lists:
                index = [
                    i
                    for i, locale_tuple in enumerate(list(locale_sequence), 0)
                    if (stats_tuple[0] in locale_tuple) or (
                        stats_tuple[0].replace('-', '_') in locale_tuple)
                ]
                if index:
                    index.append(stats_tuple[1] or 0.0)
                    new_stats_list.append(index)
            graph_data_dict[version] = self._normalize_stats(
                sorted(new_stats_list), indexes)
        stats_for_graphs_dict['graph_data'] = OrderedDict(
            sorted(graph_data_dict.items()))
        return stats_for_graphs_dict

    def get_trans_stats_by_package(self, package):
        """
        formats stats of a package for all enabled languages
        :param package: str
        :return: Graph data for "Package-wise" view: dict
        """
        if not package:
            return {}
        lang_id_name, stats_dict, pkg_desc = self.package_manager.get_trans_stats(
            package)
        upstream_stats = self.package_manager.get_upstream_stats(package)
        if upstream_stats:
            stats_dict['Upstream'] = upstream_stats
        # format trans_stats_list for graphs
        return self._format_stats_for_default_graphs(lang_id_name, stats_dict,
                                                     pkg_desc)

    def _format_stats_for_lang_wise_graphs(self, input_locale, locale_sequence,
                                           stats_dict, desc):
        """
        Formats stats dict for bar graph-ready material
        """
        stats_for_graphs_dict = OrderedDict()
        stats_branches = list(stats_dict.keys())
        stats_for_graphs_dict['pkg_desc'] = desc

        stats_for_graphs_dict['ticks'] = \
            [[i, version] for i, version in enumerate(stats_branches, 0)]

        stats_for_graphs_dict['graph_data'] = []
        for version, stats_lists in stats_dict.items():
            index = stats_branches.index(version)
            required_stat = 0.0
            for locale_tuple in list(locale_sequence.keys()):
                if input_locale in locale_tuple:
                    locale, alias = locale_tuple
                    expected_stat = [
                        stat for lang, stat in stats_lists
                        if lang.replace('-', '_') == locale
                        or lang.replace('-', '_') == alias
                    ]
                    required_stat = expected_stat[0] if expected_stat and len(
                        expected_stat) > 0 else 0.0
            stats_for_graphs_dict['graph_data'].append([required_stat, index])

        return stats_for_graphs_dict

    def get_stats_by_pkg_per_lang(self, package, locale):
        """
        formats stats of a package for given locale
        :param package: str
        :param locale: str
        :return: Graph data for "Language-wise" view: dict
        """
        if not package and not locale:
            return {}
        lang_id_name, stats_dict, pkg_desc = self.package_manager.get_trans_stats(
            package)
        # format stats for lang-wise graph
        return self._format_stats_for_lang_wise_graphs(locale, lang_id_name,
                                                       stats_dict, pkg_desc)

    def _format_stats_for_custom_graphs(self, rel_branch, languages,
                                        stats_dict):
        """
        Formats stats dict for graph-ready material
        """
        stats_for_graphs_dict = OrderedDict()
        stats_for_graphs_dict['branch'] = rel_branch
        stats_for_graphs_dict['ticks'] = \
            [[i, package] for i, package in enumerate(stats_dict.keys(), 0)]

        stats_for_graphs_dict['graph_data'] = []
        for language in languages:
            stats = []
            graph_lang_stats_dict = OrderedDict()
            graph_lang_stats_dict['label'] = language
            for lang_stat in stats_dict.values():
                stats.append(lang_stat.get(language))
            graph_lang_stats_dict['data'] = \
                [[i, stat] for i, stat in enumerate(stats, 0)]
            stats_for_graphs_dict['graph_data'].append(graph_lang_stats_dict)
        return stats_for_graphs_dict

    def get_trans_stats_by_rule(self, graph_rule):
        """
        formats stats of a graph rule
        :param: graph_rule: str
        :return: Graph data for "Rule-wise" view: dict
        """
        if not graph_rule:
            return {}
        rule = self.get_graph_rules(graph_rule=graph_rule).get()
        graph_rule_branch = rule.rule_relbranch
        release_branch = self.branch_manager.get_release_branches(
            relbranch=graph_rule_branch,
            fields=['relbranch_name']).get().relbranch_name
        packages = rule.rule_packages
        exclude_packages = []
        rule_locales = rule.rule_langs

        trans_stats_dict_set = OrderedDict()
        languages_list = []
        for package in packages:
            lang_id_name, package_stats = self.package_manager.get_trans_stats(
                package, apply_branch_mapping=True)[0:2]
            relbranch_stats = {}
            if graph_rule_branch in package_stats:
                relbranch_stats.update(package_stats.get(graph_rule_branch))
            elif 'master' in package_stats and package_stats.get('master'):
                relbranch_stats.update(package_stats.get('master'))
            elif 'default' in package_stats and package_stats.get('default'):
                relbranch_stats.update(package_stats.get('default'))
            else:
                exclude_packages.append(package)
            # filter locale_tuple for required locales
            required_locales = []
            for locale_tuple, lang in lang_id_name.items():
                rule_locale = [
                    rule_locale for rule_locale in rule_locales
                    if rule_locale in locale_tuple
                ]
                if rule_locale:
                    required_locales.append((locale_tuple, lang))
            # set stat for filtered_locale_tuple checking with both locale and alias
            lang_stats = OrderedDict()
            for locale, stat in relbranch_stats.items():
                locale = locale.replace('-', '_') if '-' in locale else locale
                for locale_tuple, lang in required_locales:
                    if locale in locale_tuple:
                        lang_stats[lang] = stat
            languages_list = lang_stats.keys()
            trans_stats_dict_set[package] = lang_stats
        # this is to prevent any breaking in graphs
        for ex_package in exclude_packages:
            trans_stats_dict_set.pop(ex_package)

        # here trans_stats_dict_set would contain {'package': {'language': stat}}
        # now, lets format trans_stats_list for graphs
        return self._format_stats_for_custom_graphs(release_branch,
                                                    languages_list,
                                                    trans_stats_dict_set)

    def _consolidate_branch_specific_stats(self, packages_stats_dict):
        """
        Sum up stats per language
        """
        temp_stats_dict = {}
        pkgs_stats_list = list(packages_stats_dict.values())
        pkgs_length = len(pkgs_stats_list)
        for pkg_stats in pkgs_stats_list:
            for pkg_stat in pkg_stats:
                if pkg_stat[0] not in temp_stats_dict:
                    temp_stats_dict[pkg_stat[0]] = pkg_stat[1]
                else:
                    temp_stats_dict[pkg_stat[0]] += pkg_stat[1]
        # Reverse stats to depict how much is left
        return sorted([(i, 100 - int(j / pkgs_length))
                       for i, j in temp_stats_dict.items()])

    def _format_data_for_pie_chart(self, consolidated_stats, lang_options):
        """
        Takes consolidated stats and formats for pie chart
        """
        formatted_stats = []
        formatted_langs = []
        for lang, stat in consolidated_stats:
            formatted_stats.append({'label': lang, 'data': stat})
        for locale, language in lang_options:
            formatted_langs.append({'value': locale, 'text': language})
        return {
            'graph_data': formatted_stats,
            'select_options': sorted(formatted_langs, key=itemgetter('text'))
        }

    def _get_branch_specific_pkgs_stats(self, relbranch):
        """
        Generates translation stats of all packages in all langs of attached lang-set
        """
        specific_pkgs = [
            package.package_name
            for package in self.package_manager.get_relbranch_specific_pkgs(
                relbranch, ['package_name'])
        ]
        all_pkgs_stats_dict = OrderedDict()
        for pkg in specific_pkgs:
            pkg_lang_stats = []
            locale_seq, trans_stats_dict, pkg_desc = \
                self.package_manager.get_trans_stats(pkg, apply_branch_mapping=True, specify_branch=relbranch)
            t_stats = self._format_stats_for_default_graphs(
                locale_seq, trans_stats_dict, pkg_desc)
            branch_stats = t_stats.get('graph_data').get(relbranch)
            langs = t_stats.get('ticks')
            if branch_stats and langs:
                pkg_lang_stats.extend(
                    list(
                        zip([lang[1] for lang in langs],
                            [stat[1] for stat in branch_stats])))
            all_pkgs_stats_dict[pkg] = pkg_lang_stats
        return all_pkgs_stats_dict

    def get_workload_graph_data(self, release_branch):
        """
        Build or generates workload graph data
        """
        consolidated_stats = self._consolidate_branch_specific_stats(
            self._get_branch_specific_pkgs_stats(release_branch))
        # get branch specific languages for select option
        locale_lang_tuple = self.package_manager.get_locale_lang_tuple(
            locales=self.package_manager.get_relbranch_locales(release_branch))
        return self._format_data_for_pie_chart(consolidated_stats,
                                               locale_lang_tuple)

    def _process_workload_combined_view(self, packages, stats_dict, fields):
        """
        Process packages stats to sum-up all locales and find avg
        """
        stats_summary_dict = OrderedDict()
        fields_dict = OrderedDict([(field, 0) for field in fields])
        [
            stats_summary_dict.update({package: fields_dict.copy()})
            for package in packages
        ]
        if not isinstance(stats_dict, dict):
            return {}
        forloop_counter = 0
        for __, stat_dict in stats_dict.items():
            forloop_counter += 1
            for pkg, detail_stat in stat_dict.items():
                for field in fields:
                    stats_summary_dict[pkg][field] += detail_stat.get(field, 0)
        for package, detail_stats_dict in stats_summary_dict.items():
            try:
                stats_summary_dict[package][fields[3]] = \
                    (detail_stats_dict.get('Untranslated', 0) /
                     detail_stats_dict.get('Total', 0) * 100)
            except ZeroDivisionError:
                # log error, pass for now
                pass
        return stats_summary_dict

    def get_workload_estimate(self, release_branch, locale=None):
        """
        Build list of packages with translation workload for a given branch
        """
        specific_locale_present = True if locale else False
        relbranch_pkgs_stats_dict = self._get_branch_specific_pkgs_stats(
            release_branch)
        relbranch_pkgs = sorted(list(relbranch_pkgs_stats_dict.keys()))

        locales = self.package_manager.get_relbranch_locales(release_branch) \
            if not specific_locale_present else [locale]
        required_stats = OrderedDict()

        HEADERS = ('Total', 'Translated', 'Untranslated', 'Remaining')

        for locale in locales:
            required_stats[locale] = OrderedDict()
            locale_alias = self.package_manager.get_locale_alias(locale)
            for package in relbranch_pkgs:
                pkg_branch_stats = PackageBranchMapping(package).branch_stats(
                    release_branch)
                for stat in pkg_branch_stats.get('stats', []):
                    locale_found = stat.get('locale')
                    if (locale_found in locale or locale_found in locale_alias
                            or locale_found.replace('-', '_') in locale
                            or locale_found.replace('-', '_') in locale_alias):
                        temp_stat_field = OrderedDict()
                        temp_stat_field['Total'] = stat.get('total', 0)
                        temp_stat_field['Translated'] = stat.get(
                            'translated', 0)
                        temp_stat_field['Untranslated'] = stat.get(
                            'untranslated', 0)
                        remaining = 0
                        try:
                            remaining = (stat.get('untranslated') /
                                         stat.get('total')) * 100
                        except ZeroDivisionError:
                            # log error, pass for now
                            pass
                        temp_stat_field['Remaining'] = remaining
                        required_stats[locale][package] = temp_stat_field

        required_stats_dict = required_stats.get(locale, {}) \
            if specific_locale_present else \
            self._process_workload_combined_view(relbranch_pkgs, required_stats, HEADERS)
        return HEADERS, OrderedDict(
            sorted(required_stats_dict.items(),
                   key=lambda x: x[1]['Remaining'],
                   reverse=True))

    def get_workload_combined(self, release_branch):
        """
        Build list of packages with translation workload for a given branch in all languages
        """
        return self.get_workload_estimate(release_branch)

    def get_workload_detailed(self, release_branch):
        """
        Build translation workload percentage for a given branch in all languages
        """
        relbranch_packages_stats = self._get_branch_specific_pkgs_stats(
            release_branch)
        locale_lang_tuple = self.package_manager.get_locale_lang_tuple(
            locales=self.package_manager.get_relbranch_locales(release_branch))
        headers = sorted([lang for locale, lang in locale_lang_tuple])
        # Format data to fill table
        workload_combined = OrderedDict()
        for package, lang_stats in relbranch_packages_stats.items():
            temp_stat_list = []
            for lang_stat_tuple in lang_stats:
                temp_stat_list.insert(headers.index(lang_stat_tuple[0]),
                                      lang_stat_tuple[1])
            # flag incorrect branch mapping
            if len([i for i in temp_stat_list
                    if i == 0]) == len(temp_stat_list):
                package += "*"
            workload_combined[package] = temp_stat_list
        return headers, OrderedDict(sorted(workload_combined.items()))

    def get_workload_combined_detailed(self, release_branch):
        """
        Build translation workload for a given branch in all langs for all pkgs
        :param release_branch: str
        :return: dict
        """
        if not isinstance(release_branch, str):
            return {}
        locale_lang_tuple = self.package_manager.get_locale_lang_tuple(
            locales=self.package_manager.get_relbranch_locales(release_branch))
        workload_combined_detailed = {}
        for locale, lang in locale_lang_tuple:
            workload_combined_detailed[lang] = \
                self.get_workload_estimate(release_branch, locale=locale)[1]
        return workload_combined_detailed
Esempio n. 9
0
class PackagesManagerTest(FixtureTestCase):

    packages_manager = PackagesManager()
    fixture = db_fixture
    datasets = [PackagesData]

    def test_get_packages(self):
        """
        Test get_packages
        """
        packages = self.packages_manager.get_packages()
        self.assertEqual(len(packages), 4)
        package_names = [
            PackagesData.package_anaconda.package_name,
            PackagesData.package_ibus.package_name
        ]
        packages = self.packages_manager.get_packages(
            pkgs=package_names).values()
        self.assertEqual(len(packages), 2)
        self.assertEqual(packages[0]['package_name'],
                         PackagesData.package_anaconda.package_name)
        self.assertEqual(packages[1]['package_name'],
                         PackagesData.package_ibus.package_name)
        # todo: test the filtering according to params
        # params = ['package_name', 'upstream_url']
        # packages = self.packages_manager.get_packages(pkgs=['ibus'], pkg_params=params)
        # self.assertTrue(set(params).issubset(vars(packages.get()).keys()))

    def test_is_package_exist(self):
        """
        Test is_package_exist
        """
        self.assertTrue(
            self.packages_manager.is_package_exist(
                PackagesData.package_anaconda.package_name))
        self.assertFalse(
            self.packages_manager.is_package_exist('otherpackage'))

    @patch('requests.get', new=mock_requests_get_add_package)
    def test_add_package(self):
        """
        Test add_package
        """
        kwargs = {
            'package_name': 'authconfig',
            'upstream_url': 'https://github.com/jcam/authconfig',
            'transplatform_slug': 'ZNTAFED',
            'release_streams': ['fedora']
        }
        package_added = self.packages_manager.add_package(**kwargs)
        self.assertTrue(package_added)
        self.assertTrue(self.packages_manager.is_package_exist('authconfig'))
        package_added = self.packages_manager.add_package(**kwargs)
        self.assertFalse(package_added)

    @patch('requests.get', new=mock_requests_get_validate_package)
    def test_validate_package(self):
        """
        Test validate_package
        """
        transplatform = TransPlatformData.platform_zanata_public.platform_slug
        package_candlepin_name = PackagesData.package_candlepin.package_name
        package_validated = self.packages_manager.validate_package(
            package_name=package_candlepin_name,
            transplatform_slug=transplatform)
        self.assertEqual(package_validated, package_candlepin_name)
        package_validated = self.packages_manager.validate_package(
            package_name='otherpackage', transplatform_slug=transplatform)
        self.assertFalse(package_validated)