Blob Blame History Raw
import subprocess
import sys
import json
from ast import literal_eval

class fonttest:


    def __init__(self, config):
        self.fontname = config["fontname"]
        self.coverage_lang_list = config["lang"]
        self.logfilepath = config["logfilepath"]
        self.out = dict()
        self.out["err"] = list()
        self.test_init()


    def execute_command(self, command_str):
        '''
        Execute cli commands and return output
        '''
        out, err = subprocess.Popen(command_str, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE).communicate()
        return (str(out, 'utf-8'), str(err, 'utf-8'))


    def get_font_family(self):
        '''
        This function will excute fc-list and create fontfamily, font file path list  
        '''
        # get font family
        font_family, err = self.execute_command("fc-list | grep {0} | cut -d':' -f2".format(self.fontname)) 
        #get all font file path
        font_filepath, err = self.execute_command("fc-list | grep {0} | cut -d':' -f1".format(self.fontname))
        font_filepath = font_filepath.split("\n")
        self.out["font file list"] = list(filter(None, font_filepath))

        # if font file exist create a font family list
        if not err and font_family:
            font_family = set(font_family.split("\n"))
            font_family = map(str.strip, font_family)
            self.out["font family list"] = list(filter(None, font_family))
            # return self.out_font_family
        else:
            self.out["err"].append("invalid test or parameter in font family test")
            self.out["err"].append(err)
            sys.stdout.write("invalid test or parameter in font family test")
        

    def get_font_conf(self):
        '''
        This function will get all conf file path for given font
        '''

        # get list of font conf files 
        font_conflist, err = self.execute_command("fc-conflist | grep {0}".format(self.fontname))
        
        if not err and font_conflist: 
            font_conflist = font_conflist.split("\n")
            self.out["font conf list"] = list(filter(None, font_conflist))
        else:
            self.out["err"].append("invalid test or parameter in font conf test")
            self.out["err"].append(err)
            sys.stdout.write("invalid test or parameter in font conf test")

    def get_lang_coverage(self):
        '''
        This function will check language coverage as specifed in parameter with fontfiles 
        '''

        self.out["lang covarage"] = dict()
        for font_file_path in self.out["font file list"]:
            # get all lang covarage by font    
            font_langlist, err = self.execute_command("fc-query -f 'lang: %{lang}' "+font_file_path) 
            PendingDeprecationWarning
            if not err and font_langlist: 
                font_langlist = font_langlist.split("|")
                font_langlist[0] = font_langlist[0].replace("lang: ","")
                out_lang_dict = dict()
                for lang in self.coverage_lang_list:
                    out_lang_dict[lang] = lang in font_langlist
                
                self.out["lang covarage"][font_file_path] = out_lang_dict

                if False in out_lang_dict.values():
                    self.out["err"].append("one or more lang coverage failed for font file:{0}".format(font_file_path))
                    self.out["err"].append(out_lang_dict)
                    sys.stdout.write("fail")
            else:
                self.out["err"].append("invalid test or parameter in font lang coverage test")
                self.out["err"].append(err)
                sys.stdout.write("invalid test or parameter in font lang coverage test")
    

    def testlog_generator(self):
        '''
        This function will generate a testlog and dump all metainfo generated into /tmp/test.log
        '''
        with open(self.logfilepath, "w") as file:

            file.write("\nErrors:\n")
            if not self.out["err"]:     
                file.write("No errors")
            else:
                Json = json.dumps(self.out["err"])
                file.write(Json)    

            file.write("\n\nFont Family list:\n")
            file.write("\n".join(self.out["font family list"]))

            file.write("\n\nFont conf list:\n")
            file.write("\n".join(self.out["font conf list"]))
            
            file.write("\n\nFont file list:\n")
            file.write("\n".join(self.out["font file list"]))
            
            file.write("\n\nLang coverage:\n")
            Json = json.dumps(self.out["lang covarage"])
            for key, value in self.out["lang covarage"].items():
                jvalue = json.dumps(value)
                file.write(key +" : "+ jvalue+"\n")


    def test_init(self):
        '''
        This function invokes all other test methods.
        '''
        
        self.get_font_family()
        self.get_font_conf()
        self.get_lang_coverage()
        self.testlog_generator()

        if self.out["err"]:
            sys.stderr.write("Test failed\n")
        else:
            sys.stdout.write("All Test Passed\n")


if __name__ == "__main__":
    config = literal_eval(sys.argv[1])
    fonttest(config)