Example #1
0
 def test_parserFortranVoidCode(self):
     fortran = FortranParser()
     fortran.parse(mod)
     obtained = [ref.name for ref in fortran.includes]
     obtained.extend([ref.name for ref in fortran.references])
     expected = []
     self.assertEqual(expected, obtained)
     self.assertEqual(fortran.has_main_function(), False)
Example #2
0
 def test_parserFortranCode(self):
     fortran = FortranParser()
     fortran.parse(mod)
     obtained = fortran.definitions
     expected = set([FItem('subprogram', 'sub3', ''),
                     FItem('subprogram', 'sub1', ''),
                     FItem('subprogram', 'sub2', ''),
                     FItem('module', 'mod', ''),
                     ])
     self.assertEqual(expected, obtained)
     self.assertEqual(fortran.has_main_function(), False)
Example #3
0
    def test_find_implicit_deps(self):
        parser = FortranParser()
        parser.parse(main)

        parser_two = FortranParser()
        parser_two.parse(mod)

        self.assertTrue(parser.findImplicit(parser_two))
Example #4
0
 def test_parserFortranTypes(self):
     fortran = FortranParser()
     fortran.parse(main)
     obtained = [ref.name for ref in fortran.includes]
     expected = ['qweqwe/qweqwe/stuff', 'qweqwe/qweqwe/stuffs']
     self.assertEqual(expected, obtained)
     obtained = fortran.declarations
     expected = set([
                     FItem('subprogram', 'sub3', ''),
                     FItem('subprogram', 'sub1', ''),
                     FItem('subprogram', 'sub2', ''),
                     ])
     self.assertEqual(expected, obtained)
     expected_modules = set([FItem('module', 'mod', 'hamilton/math'),
                             FItem('module', 'matrix')])
     self.assertItemsEqual(expected_modules, fortran.modules)
     self.assertTrue(fortran.has_main_function())
Example #5
0
    def test_find_implicit_deps2(self):
        parser = FortranParser()
        parser.parse(main)
        parser_two = FortranParser()
        mod = '''
        MODULE mod

        CONTAINS

          subroutine bin_array(n,x,y,n_bin,xmin,xmax,x_bin,y_bin)

            implicit none

            y_bin = s / c

          end subroutine bin_array
        END MODULE mod
        '''
        parser_two.parse(mod)
        self.assertTrue(parser.findImplicit(parser_two))
Example #6
0
 def test_find_includes_inside_module(self):
     parser = FortranParser()
     parser.parse(real)
     includes = [include.name for include in parser.includes]
     self.assertItemsEqual(["testuser1/hello/hello.f90", "hello.f90"], includes)