<86>Sep 12 09:13:16 userdel[3693685]: delete user 'rooter' <86>Sep 12 09:13:16 userdel[3693685]: removed group 'rooter' owned by 'rooter' <86>Sep 12 09:13:16 userdel[3693685]: removed shadow group 'rooter' owned by 'rooter' <86>Sep 12 09:13:16 groupadd[3693690]: group added to /etc/group: name=rooter, GID=597 <86>Sep 12 09:13:16 groupadd[3693690]: group added to /etc/gshadow: name=rooter <86>Sep 12 09:13:16 groupadd[3693690]: new group: name=rooter, GID=597 <86>Sep 12 09:13:16 useradd[3693694]: new user: name=rooter, UID=597, GID=597, home=/root, shell=/bin/bash <86>Sep 12 09:13:16 userdel[3693701]: delete user 'builder' <86>Sep 12 09:13:16 userdel[3693701]: removed group 'builder' owned by 'builder' <86>Sep 12 09:13:16 userdel[3693701]: removed shadow group 'builder' owned by 'builder' <86>Sep 12 09:13:16 groupadd[3693706]: group added to /etc/group: name=builder, GID=598 <86>Sep 12 09:13:16 groupadd[3693706]: group added to /etc/gshadow: name=builder <86>Sep 12 09:13:16 groupadd[3693706]: new group: name=builder, GID=598 <86>Sep 12 09:13:16 useradd[3693710]: new user: name=builder, UID=598, GID=598, home=/usr/src, shell=/bin/bash <13>Sep 12 09:13:19 rpmi: libgdbm-1.8.3-alt10 1454943334 installed <13>Sep 12 09:13:19 rpmi: libexpat-2.2.9-alt1 sisyphus+252464.200.2.1 1590958865 installed <13>Sep 12 09:13:19 rpmi: libp11-kit-0.23.15-alt2 sisyphus+252784.100.2.2 1591274901 installed <13>Sep 12 09:13:19 rpmi: libtasn1-4.16.0-alt1 sisyphus+245480.100.1.1 1580825062 installed <13>Sep 12 09:13:19 rpmi: rpm-macros-alternatives-0.5.1-alt1 sisyphus+226946.100.1.1 1554830426 installed <13>Sep 12 09:13:19 rpmi: alternatives-0.5.1-alt1 sisyphus+226946.100.1.1 1554830426 installed <13>Sep 12 09:13:19 rpmi: ca-certificates-2020.06.29-alt1 sisyphus+254237.300.1.1 1593450881 installed <13>Sep 12 09:13:19 rpmi: ca-trust-0.1.2-alt1 sisyphus+233348.100.1.1 1561653823 installed <13>Sep 12 09:13:19 rpmi: p11-kit-trust-0.23.15-alt2 sisyphus+252784.100.2.2 1591274901 installed <13>Sep 12 09:13:20 rpmi: libcrypto1.1-1.1.1g-alt1 sisyphus+249982.60.8.1 1587743711 installed <13>Sep 12 09:13:20 rpmi: libssl1.1-1.1.1g-alt1 sisyphus+249982.60.8.1 1587743711 installed <13>Sep 12 09:13:20 rpmi: python3-3.8.5-alt1 sisyphus+244405.100.3.1 1595544514 installed <13>Sep 12 09:13:21 rpmi: python3-base-3.8.5-alt1 sisyphus+244405.100.3.1 1595544514 installed <13>Sep 12 09:13:21 rpmi: libpython3-3.8.5-alt1 sisyphus+244405.100.3.1 1595544514 installed <13>Sep 12 09:13:21 rpmi: tests-for-installed-python3-pkgs-0.1.13.1-alt2 1535450458 installed <13>Sep 12 09:13:21 rpmi: rpm-build-python3-0.1.13.1-alt2 1535450458 installed <13>Sep 12 09:13:25 rpmi: python3-module-pkg_resources-1:46.1.3-alt1 sisyphus+250566.200.3.1 1587973342 installed <13>Sep 12 09:13:25 rpmi: python-modules-curses-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:25 rpmi: libtinfo-devel-6.1.20180407-alt2 sisyphus+222164.200.1.1 1550686226 installed <13>Sep 12 09:13:25 rpmi: libncurses-devel-6.1.20180407-alt2 sisyphus+222164.200.1.1 1550686226 installed <13>Sep 12 09:13:25 rpmi: python3-dev-3.8.5-alt1 sisyphus+244405.100.3.1 1595544514 installed <13>Sep 12 09:13:25 rpmi: libverto-0.3.0-alt1_7 sisyphus+225932.100.1.1 1553994919 installed <13>Sep 12 09:13:25 rpmi: liblmdb-0.9.23-alt1 sisyphus+225277.100.2.1 1553001679 installed <13>Sep 12 09:13:25 rpmi: libkeyutils-1.6.1-alt1 sisyphus+256015.100.1.1 1596820124 installed <13>Sep 12 09:13:25 rpmi: libcom_err-1.44.6-alt1 sisyphus+224154.100.1.1 1552091678 installed <86>Sep 12 09:13:25 groupadd[3699598]: group added to /etc/group: name=_keytab, GID=499 <86>Sep 12 09:13:25 groupadd[3699598]: group added to /etc/gshadow: name=_keytab <86>Sep 12 09:13:25 groupadd[3699598]: new group: name=_keytab, GID=499 <13>Sep 12 09:13:25 rpmi: libkrb5-1.18.2-alt2 sisyphus+254565.100.4.1 1594375666 installed <13>Sep 12 09:13:25 rpmi: libtirpc-1.2.6-alt1 sisyphus+250076.100.1.1 1587038270 installed <13>Sep 12 09:13:25 rpmi: libnsl2-1.1.0-alt1_1 1511548749 installed <13>Sep 12 09:13:25 rpmi: python-modules-compiler-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:25 rpmi: python-modules-email-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:25 rpmi: python-modules-unittest-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:25 rpmi: python-modules-encodings-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-modules-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-modules-nis-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-modules-ctypes-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-modules-multiprocessing-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-modules-logging-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-tools-2to3-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-modules-xml-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-modules-hotshot-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-modules-bsddb-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-modules-distutils-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-module-pkg_resources-1:42.0.0-alt3 sisyphus+257539.100.1.1 1599462744 installed <13>Sep 12 09:13:26 rpmi: python-modules-json-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: libnsl2-devel-1.1.0-alt1_1 1511548749 installed <13>Sep 12 09:13:26 rpmi: python-dev-2.7.18-alt1 sisyphus+255741.100.1.1 1596450480 installed <13>Sep 12 09:13:26 rpmi: python-module-setuptools-1:42.0.0-alt3 sisyphus+257539.100.1.1 1599462744 installed <13>Sep 12 09:13:26 rpmi: python3-module-setuptools-1:46.1.3-alt1 sisyphus+250566.200.3.1 1587973342 installed Building target platforms: i586 Building for target i586 Wrote: /usr/src/in/nosrpm/python-module-gflags-2.0-alt2.1.3.nosrc.rpm Installing python-module-gflags-2.0-alt2.1.3.src.rpm Building target platforms: i586 Building for target i586 Executing(%prep): /bin/sh -e /usr/src/tmp/rpm-tmp.59278 + umask 022 + /bin/mkdir -p /usr/src/RPM/BUILD + cd /usr/src/RPM/BUILD + cd /usr/src/RPM/BUILD + rm -rf python-module-gflags-2.0 + echo 'Source #0 (python-module-gflags-2.0.tar):' Source #0 (python-module-gflags-2.0.tar): + /bin/tar -xf /usr/src/RPM/SOURCES/python-module-gflags-2.0.tar + cd python-module-gflags-2.0 + /bin/chmod -c -Rf u+rwX,go-w . + cp -fR . ../python3 + exit 0 Executing(%build): /bin/sh -e /usr/src/tmp/rpm-tmp.59278 + umask 022 + /bin/mkdir -p /usr/src/RPM/BUILD + cd /usr/src/RPM/BUILD + cd python-module-gflags-2.0 + CFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export CFLAGS + CXXFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export CXXFLAGS + FFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export FFLAGS + /usr/bin/python2.7 setup.py build --debug running build running build_py creating build creating build/lib copying gflags.py -> build/lib copying gflags_validators.py -> build/lib running egg_info writing python_gflags.egg-info/PKG-INFO writing top-level names to python_gflags.egg-info/top_level.txt writing dependency_links to python_gflags.egg-info/dependency_links.txt reading manifest file 'python_gflags.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' writing manifest file 'python_gflags.egg-info/SOURCES.txt' + pushd ../python3 ~/RPM/BUILD/python3 ~/RPM/BUILD/python-module-gflags-2.0 + find -type f -name '*.py' -exec 2to3 -w -n '{}' + RefactoringTool: Skipping optional fixer: buffer RefactoringTool: Skipping optional fixer: idioms RefactoringTool: Skipping optional fixer: set_literal RefactoringTool: Skipping optional fixer: ws_comma RefactoringTool: Refactored ./tests/gflags_validators_test.py RefactoringTool: Refactored ./tests/gflags_unittest.py --- ./tests/gflags_validators_test.py (original) +++ ./tests/gflags_validators_test.py (refactored) @@ -63,10 +63,10 @@ argv = ('./program') self.flag_values(argv) - self.assertEquals(None, self.flag_values.test_flag) + self.assertEqual(None, self.flag_values.test_flag) self.flag_values.test_flag = 2 - self.assertEquals(2, self.flag_values.test_flag) - self.assertEquals([None, 2], self.call_args) + self.assertEqual(2, self.flag_values.test_flag) + self.assertEqual([None, 2], self.call_args) def testDefaultValueNotUsedSuccess(self): def Checker(x): @@ -81,8 +81,8 @@ argv = ('./program', '--test_flag=1') self.flag_values(argv) - self.assertEquals(1, self.flag_values.test_flag) - self.assertEquals([1], self.call_args) + self.assertEqual(1, self.flag_values.test_flag) + self.assertEqual([1], self.call_args) def testValidatorNotCalledWhenOtherFlagIsChanged(self): def Checker(x): @@ -99,9 +99,9 @@ argv = ('./program') self.flag_values(argv) - self.assertEquals(1, self.flag_values.test_flag) + self.assertEqual(1, self.flag_values.test_flag) self.flag_values.other_flag = 3 - self.assertEquals([1], self.call_args) + self.assertEqual([1], self.call_args) def testExceptionRaisedIfCheckerFails(self): def Checker(x): @@ -119,9 +119,9 @@ try: self.flag_values.test_flag = 2 raise AssertionError('gflags.IllegalFlagValue expected') - except gflags.IllegalFlagValue, e: - self.assertEquals('flag --test_flag=2: Errors happen', str(e)) - self.assertEquals([1, 2], self.call_args) + except gflags.IllegalFlagValue as e: + self.assertEqual('flag --test_flag=2: Errors happen', str(e)) + self.assertEqual([1, 2], self.call_args) def testExceptionRaisedIfCheckerRaisesException(self): def Checker(x): @@ -141,9 +141,9 @@ try: self.flag_values.test_flag = 2 raise AssertionError('gflags.IllegalFlagValue expected') - except gflags.IllegalFlagValue, e: - self.assertEquals('flag --test_flag=2: Specific message', str(e)) - self.assertEquals([1, 2], self.call_args) + except gflags.IllegalFlagValue as e: + self.assertEqual('flag --test_flag=2: Specific message', str(e)) + self.assertEqual([1, 2], self.call_args) def testErrorMessageWhenCheckerReturnsFalseOnStart(self): def Checker(x): @@ -160,9 +160,9 @@ try: self.flag_values(argv) raise AssertionError('gflags.IllegalFlagValue expected') - except gflags.IllegalFlagValue, e: - self.assertEquals('flag --test_flag=1: Errors happen', str(e)) - self.assertEquals([1], self.call_args) + except gflags.IllegalFlagValue as e: + self.assertEqual('flag --test_flag=1: Errors happen', str(e)) + self.assertEqual([1], self.call_args) def testErrorMessageWhenCheckerRaisesExceptionOnStart(self): def Checker(x): @@ -179,9 +179,9 @@ try: self.flag_values(argv) raise AssertionError('IllegalFlagValue expected') - except gflags.IllegalFlagValue, e: - self.assertEquals('flag --test_flag=1: Specific message', str(e)) - self.assertEquals([1], self.call_args) + except gflags.IllegalFlagValue as e: + self.assertEqual('flag --test_flag=1: Specific message', str(e)) + self.assertEqual([1], self.call_args) def testValidatorsCheckedInOrder(self): @@ -195,11 +195,11 @@ self.calls = [] self._DefineFlagAndValidators(Required, Even) - self.assertEquals(['Required', 'Even'], self.calls) + self.assertEqual(['Required', 'Even'], self.calls) self.calls = [] self._DefineFlagAndValidators(Even, Required) - self.assertEquals(['Even', 'Required'], self.calls) + self.assertEqual(['Even', 'Required'], self.calls) def _DefineFlagAndValidators(self, first_validator, second_validator): local_flags = gflags.FlagValues() --- ./tests/gflags_unittest.py (original) +++ ./tests/gflags_unittest.py (refactored) @@ -34,7 +34,7 @@ __pychecker__ = "no-local" # for unittest -import cStringIO +import io import sys import os import shutil @@ -169,8 +169,8 @@ assert 'numbers' in FLAGS.RegisteredFlags() # has_key - assert FLAGS.has_key('name') - assert not FLAGS.has_key('name2') + assert 'name' in FLAGS + assert 'name2' not in FLAGS assert 'name' in FLAGS assert 'name2' not in FLAGS @@ -216,24 +216,24 @@ # Test integer argument passing argv = ('./program', '--x', '0x12345') argv = FLAGS(argv) - self.assertEquals(FLAGS.x, 0x12345) - self.assertEquals(type(FLAGS.x), int) + self.assertEqual(FLAGS.x, 0x12345) + self.assertEqual(type(FLAGS.x), int) argv = ('./program', '--x', '0x1234567890ABCDEF1234567890ABCDEF') argv = FLAGS(argv) - self.assertEquals(FLAGS.x, 0x1234567890ABCDEF1234567890ABCDEF) - self.assertEquals(type(FLAGS.x), long) + self.assertEqual(FLAGS.x, 0x1234567890ABCDEF1234567890ABCDEF) + self.assertEqual(type(FLAGS.x), int) # Treat 0-prefixed parameters as base-10, not base-8 argv = ('./program', '--x', '012345') argv = FLAGS(argv) - self.assertEquals(FLAGS.x, 12345) - self.assertEquals(type(FLAGS.x), int) + self.assertEqual(FLAGS.x, 12345) + self.assertEqual(type(FLAGS.x), int) argv = ('./program', '--x', '0123459') argv = FLAGS(argv) - self.assertEquals(FLAGS.x, 123459) - self.assertEquals(type(FLAGS.x), int) + self.assertEqual(FLAGS.x, 123459) + self.assertEqual(type(FLAGS.x), int) argv = ('./program', '--x', '0x123efg') try: @@ -314,7 +314,7 @@ for lst in lists: argv = ('./program', '--%s=%s' % (name, sep.join(lst))) argv = FLAGS(argv) - self.assertEquals(getattr(FLAGS, name), lst) + self.assertEqual(getattr(FLAGS, name), lst) # Test help text flagsHelp = str(FLAGS) @@ -497,7 +497,7 @@ gflags.DEFINE_boolean("zoom1", 0, "runhelp z1", short_name='z') gflags.DEFINE_boolean("zoom2", 0, "runhelp z2", short_name='z') raise AssertionError("duplicate short flag detection failed") - except gflags.DuplicateFlag, e: + except gflags.DuplicateFlag as e: self.assertTrue("The flag 'z' is defined twice. " in e.args[0]) self.assertTrue("First from" in e.args[0]) self.assertTrue(", Second from" in e.args[0]) @@ -507,7 +507,7 @@ gflags.DEFINE_boolean("short1", 0, "runhelp s1", short_name='s') gflags.DEFINE_boolean("s", 0, "runhelp s2") raise AssertionError("duplicate mixed flag detection failed") - except gflags.DuplicateFlag, e: + except gflags.DuplicateFlag as e: self.assertTrue("The flag 's' is defined twice. " in e.args[0]) self.assertTrue("First from" in e.args[0]) self.assertTrue(", Second from" in e.args[0]) @@ -521,7 +521,7 @@ duplicate_flags = module_foo.DuplicateFlags(flagnames) try: original_flags.AppendFlagValues(duplicate_flags) - except gflags.DuplicateFlagError, e: + except gflags.DuplicateFlagError as e: self.assertTrue("flags_unittest" in str(e)) self.assertTrue("module_foo" in str(e)) @@ -580,8 +580,8 @@ allow_override=1) gflags.DEFINE_boolean("dup3", 1, "runhelp d32", short_name='u', allow_override=1) - self.assert_(str(FLAGS).find('runhelp d31') == -1) - self.assert_(str(FLAGS).find('runhelp d32') != -1) + self.assertTrue(str(FLAGS).find('runhelp d31') == -1) + self.assertTrue(str(FLAGS).find('runhelp d32') != -1) # Make sure AppendFlagValues works new_flags = gflags.FlagValues() @@ -782,12 +782,12 @@ 'float option that can occur multiple times', short_name='mf') for (expected, actual) in zip(float_defaults, FLAGS.get('m_float', None)): - self.assertAlmostEquals(expected, actual) + self.assertAlmostEqual(expected, actual) argv = ('./program', '--m_float=-17', '--mf=2.78e9') FLAGS(argv) expected_floats = [-17.0, 2.78e9] for (expected, actual) in zip(expected_floats, FLAGS.get('m_float', None)): - self.assertAlmostEquals(expected, actual) + self.assertAlmostEqual(expected, actual) def testSingleValueDefault(self): """Test multi_int and multi_float flags with a single default value.""" @@ -800,8 +800,8 @@ gflags.DEFINE_multi_float('m_float1', float_default, 'float option that can occur multiple times') actual = FLAGS.get('m_float1', None) - self.assertEquals(1, len(actual)) - self.assertAlmostEquals(actual[0], float_default) + self.assertEqual(1, len(actual)) + self.assertAlmostEqual(actual[0], float_default) def testBadMultiNumericalFlags(self): """Test multi_int and multi_float flags with non-parseable values.""" @@ -866,7 +866,7 @@ gflags.DEFINE_list("non_unicode", ["abc", "def", "ghi"], "help:\xC3\xAD".decode("utf-8")) - outfile = cStringIO.StringIO() + outfile = io.StringIO() FLAGS.WriteHelpInXMLFormat(outfile) actual_output = outfile.getvalue() @@ -924,9 +924,9 @@ tmp_flag_file_2 = open(tmp_path + '/UnitTestFile2.tst', 'w') tmp_flag_file_3 = open(tmp_path + '/UnitTestFile3.tst', 'w') tmp_flag_file_4 = open(tmp_path + '/UnitTestFile4.tst', 'w') - except IOError, e_msg: - print e_msg - print 'FAIL\n File Creation problem in Unit Test' + except IOError as e_msg: + print(e_msg) + print('FAIL\n File Creation problem in Unit Test') sys.exit(1) # put some dummy flags in our test files @@ -971,8 +971,8 @@ for file_name in self.files_to_delete: try: os.remove(file_name) - except OSError, e_msg: - print '%s\n, Problem deleting test file' % e_msg + except OSError as e_msg: + print('%s\n, Problem deleting test file' % e_msg) #end RemoveTestFiles def def _ReadFlagsFromFiles(self, argv, force_gnu): @@ -1261,8 +1261,8 @@ 'nocommon': 'nocommon', 'common': 'common'} - for name, shorter in expected_results.iteritems(): - self.assertEquals(shorter_flags[name], shorter) + for name, shorter in expected_results.items(): + self.assertEqual(shorter_flags[name], shorter) self.flag_values.__delattr__('a') self.flag_values.__delattr__('abc') @@ -1322,7 +1322,7 @@ argv = ('./program', '--nosuchflag', '--name=Bob', 'extra') self.flag_values(argv) raise AssertionError("Unknown flag exception not raised") - except gflags.UnrecognizedFlag, e: + except gflags.UnrecognizedFlag as e: assert e.flagname == 'nosuchflag' assert e.flagvalue == '--nosuchflag' @@ -1331,7 +1331,7 @@ argv = ('./program', '-w', '--name=Bob', 'extra') self.flag_values(argv) raise AssertionError("Unknown flag exception not raised") - except gflags.UnrecognizedFlag, e: + except gflags.UnrecognizedFlag as e: assert e.flagname == 'w' assert e.flagvalue == '-w' @@ -1340,7 +1340,7 @@ argv = ('./program', '--nosuchflagwithparam=foo', '--name=Bob', 'extra') self.flag_values(argv) raise AssertionError("Unknown flag exception not raised") - except gflags.UnrecognizedFlag, e: + except gflags.UnrecognizedFlag as e: assert e.flagname == 'nosuchflagwithparam' assert e.flagvalue == '--nosuchflagwithparam=foo' @@ -1366,7 +1366,7 @@ '--undefok=nosuchfla', 'extra') self.flag_values(argv) raise AssertionError("Unknown flag exception not raised") - except gflags.UnrecognizedFlag, e: + except gflags.UnrecognizedFlag as e: assert e.flagname == 'nosuchflag' try: @@ -1374,7 +1374,7 @@ '--undefok=nosuchflagg', 'extra') self.flag_values(argv) raise AssertionError("Unknown flag exception not raised") - except gflags.UnrecognizedFlag, e: + except gflags.UnrecognizedFlag as e: assert e.flagname == 'nosuchflag' # Allow unknown short flag -w if specified with undefok @@ -1409,7 +1409,7 @@ '--undefok=another_such', 'extra') self.flag_values(argv) RefactoringTool: Refactored ./tests/gflags_helpxml_test.py RefactoringTool: Refactored ./tests/gflags_googletest.py raise AssertionError("Unknown flag exception not raised") - except gflags.UnrecognizedFlag, e: + except gflags.UnrecognizedFlag as e: assert e.flagname == 'nosuchflag' # Make sure --undefok doesn't mask other option errors. @@ -1458,7 +1458,7 @@ try: argv = nonglobal_flags(argv) raise AssertionError("Unknown flag exception not raised") - except gflags.UnrecognizedFlag, e: + except gflags.UnrecognizedFlag as e: assert e.flagname == 'nosuchflag' pass @@ -1491,7 +1491,7 @@ flag_values = gflags.FlagValues() gflags.DEFINE_string('delattr_foo', default_value, 'A simple flag.', flag_values=flag_values) - self.assertEquals(flag_values.delattr_foo, default_value) + self.assertEqual(flag_values.delattr_foo, default_value) flag_obj = flag_values['delattr_foo'] # We also check that _FlagIsRegistered works as expected :) self.assertTrue(flag_values._FlagIsRegistered(flag_obj)) @@ -1934,11 +1934,11 @@ try: self.flag_values.__setattr__(flag_name, flag_value) raise AssertionError('Bounds exception not raised!') - except gflags.IllegalFlagValue, e: + except gflags.IllegalFlagValue as e: expected = ('flag --%(name)s=%(value)s: %(value)s is not %(suffix)s' % {'name': flag_name, 'value': flag_value, 'suffix': expected_message_suffix}) - self.assertEquals(str(e), expected) + self.assertEqual(str(e), expected) def main(): --- ./tests/gflags_helpxml_test.py (original) +++ ./tests/gflags_helpxml_test.py (refactored) @@ -35,7 +35,7 @@ import string -import StringIO +import io import sys import xml.dom.minidom import xml.sax.saxutils @@ -96,7 +96,7 @@ def _CheckFlagHelpInXML(self, flag_name, module_name, expected_output, is_key=False): # StringIO.StringIO is a file object that writes into a memory string. - sio = StringIO.StringIO() + sio = io.StringIO() flag_obj = self.fv[flag_name] flag_obj.WriteInfoInXMLFormat(sio, module_name, is_key=is_key, indent=' ') self.assertMultiLineEqual(sio.getvalue(), expected_output) @@ -496,7 +496,7 @@ gflags.DECLARE_key_flag('tmod_bar_u', flag_values=fv) # Generate flag help in XML format in the StringIO sio. - sio = StringIO.StringIO() + sio = io.StringIO() fv.WriteHelpInXMLFormat(sio) # Check that we got the expected result. --- ./tests/gflags_googletest.py (original) +++ ./tests/gflags_googletest.py (refactored) @@ -49,10 +49,10 @@ if actual == expected: return True - print "Error: FLAGS.MainModuleHelp() didn't return the expected result." - print "Got:" - print actual - print "[End of got]" + print("Error: FLAGS.MainModuleHelp() didn't return the expected result.") + print("Got:") + print(actual) + print("[End of got]") actual_lines = actual.split("\n") expected_lines = expected.split("\n") @@ -61,28 +61,28 @@ num_expected_lines = len(expected_lines) if num_actual_lines != num_expected_lines: - print "Number of actual lines = %d, expected %d" % ( - num_actual_lines, num_expected_lines) + print("Number of actual lines = %d, expected %d" % ( + num_actual_lines, num_expected_lines)) num_to_match = min(num_actual_lines, num_expected_lines) for i in range(num_to_match): if actual_lines[i] != expected_lines[i]: - print "One discrepancy: Got:" - print actual_lines[i] - print "Expected:" - print expected_lines[i] + print("One discrepancy: Got:") + print(actual_lines[i]) + print("Expected:") + print(expected_lines[i]) break else: # If we got here, found no discrepancy, print first new line. if num_actual_lines > num_expected_lines: - print "New help line:" - print actual_lines[num_expected_lines] + print("New help line:") + print(actual_lines[num_expected_lines]) elif num_expected_lines > num_actual_lines: - print "Missing expected help line:" - print expected_lRefactoringTool: No changes to ./tests/flags_modules_for_testing/module_foo.py RefactoringTool: No changes to ./tests/flags_modules_for_testing/module_baz.py RefactoringTool: Refactored ./tests/flags_modules_for_testing/module_bar.py RefactoringTool: No changes to ./setup.py RefactoringTool: No changes to ./gflags_validators.py RefactoringTool: Refactored ./gflags2man.py RefactoringTool: Refactored ./gflags.py ines[num_actual_lines] + print("Missing expected help line:") + print(expected_lines[num_actual_lines]) else: - print "Bug in this test -- discrepancy detected but not found." + print("Bug in this test -- discrepancy detected but not found.") return False @@ -108,7 +108,7 @@ def assertRaisesWithRegexpMatch(self, exception, regexp, fn, *args, **kwargs): try: fn(*args, **kwargs) - except exception, why: + except exception as why: self.assertTrue(re.search(regexp, str(why)), "'%s' does not match '%s'" % (regexp, why)) return --- ./tests/flags_modules_for_testing/module_bar.py (original) +++ ./tests/flags_modules_for_testing/module_bar.py (refactored) @@ -132,4 +132,4 @@ """ # Indeed, using exec generates a lint warning. But some user code # actually uses exec, and we have to test for it ... - exec code in global_dict + exec(code, global_dict) --- ./gflags2man.py (original) +++ ./gflags2man.py (refactored) @@ -81,18 +81,18 @@ class Logging: """A super-simple logging class""" - def error(self, msg): print >>sys.stderr, "ERROR: ", msg - def warn(self, msg): print >>sys.stderr, "WARNING: ", msg - def info(self, msg): print msg + def error(self, msg): print("ERROR: ", msg, file=sys.stderr) + def warn(self, msg): print("WARNING: ", msg, file=sys.stderr) + def info(self, msg): print(msg) def debug(self, msg): self.vlog(1, msg) def vlog(self, level, msg): - if FLAGS.v >= level: print msg + if FLAGS.v >= level: print(msg) logging = Logging() class App: def usage(self, shorthelp=0): - print >>sys.stderr, __doc__ - print >>sys.stderr, "flags:" - print >>sys.stderr, str(FLAGS) + print(__doc__, file=sys.stderr) + print("flags:", file=sys.stderr) + print(str(FLAGS), file=sys.stderr) def run(self): main(sys.argv) app = App() --- ./gflags.py (original) +++ ./gflags.py (refactored) @@ -583,7 +583,7 @@ space_prefix_len = len(common_prefix) - len(common_prefix.lstrip()) # If we have a common space prefix, drop it from all lines if space_prefix_len: - for index in xrange(len(text_lines)): + for index in range(len(text_lines)): if text_lines[index]: text_lines[index] = text_lines[index][space_prefix_len:] return '\n'.join(text_first_line + text_lines) @@ -745,7 +745,7 @@ # a parallel thread imports a module while we iterate over # .iteritems() (not nice, but possible), we get a RuntimeError ... # Hence, we use the slightly slower but safer .items(). - for name, module in sys.modules.items(): + for name, module in list(sys.modules.items()): if getattr(module, '__dict__', None) is globals_dict: if name == '__main__': # Pick a more informative name for the main module. @@ -964,7 +964,7 @@ If no such module exists (i.e. no flag with this name exists), we return default. """ - for module, flags in self.FlagsByModuleDict().iteritems(): + for module, flags in self.FlagsByModuleDict().items(): for flag in flags: if flag.name == flagname or flag.short_name == flagname: return module @@ -983,7 +983,7 @@ If no such module exists (i.e. no flag with this name exists), we return default. """ - for module_id, flags in self.FlagsByModuleIdDict().iteritems(): + for module_id, flags in self.FlagsByModuleIdDict().items(): for flag in flags: if flag.name == flagname or flag.short_name == flagname: return module_id @@ -995,7 +995,7 @@ Args: flag_values: registry to copy from """ - for flag_name, flag in flag_values.FlagDict().iteritems(): + for flag_name, flag in flag_values.FlagDict().items(): # Each flags with shortname appears here twice (once under its # normal name, and again with its short name). To prevent # problems (DuplicateFlagError) with double flag registration, we @@ -1068,7 +1068,7 @@ def _AssertAllValidators(self): all_validators = set() - for flag in self.FlagDict().itervalues(): + for flag in self.FlagDict().values(): for validator in flag.validators: all_validators.add(validator) self._AssertValidators(all_validators) @@ -1088,7 +1088,7 @@ validators, key=lambda validator: validator.insertion_index): try: validator.Verify(self) - except gflags_validators.Error, e: + except gflags_validators.Error as e: message = validator.PrintFlagsWithValues(self) raise IllegalFlagValue('%s: %s' % (message, str(e))) @@ -1163,7 +1163,7 @@ flags. flag_obj: A flag object. """ - for unused_module, flags_in_module in flags_by_module_dict.iteritems(): + for unused_module, flags_in_module in flags_by_module_dict.items(): # while (as opposed to if) takes care of multiple occurrences of a # flag in the list for the same module. while flag_obj in flags_in_module: @@ -1222,7 +1222,7 @@ # full forms: --mybool=(true|false). original_argv = list(argv) # list() makes a copy shortest_matches = None - for name, flag in fl.items(): + for name, flag in list(fl.items()): if not flag.boolean: continue if shortest_matches is None: @@ -1246,7 +1246,7 @@ # specified as a string of letters, each letter followed by a colon # if it takes an argument. Long options are stored in an array of # strings. Each string ends with an '=' if it takes an argument. - for name, flag in fl.items(): + for name, flag in list(fl.items()): longopts.append(name + "=") if len(name) == 1: # one-letter option: allow short flag type also shortopts += name @@ -1267,7 +1267,7 @@ else: optlist, unparsed_args = getopt.getopt(args, shortopts, longopts) break - except getopt.GetoptError, e: + except getopt.GetoptError as e: if not e.opt or e.opt in fl: # Not an unrecognized option, re-raise the exception as a FlagsError raise FlagsError(e) @@ -1335,7 +1335,7 @@ def Reset(self): """Resets the values to the point before FLAGS(argv) was called.""" - for f in self.FlagDict().values(): + for f in list(self.FlagDict().values()): f.Unparse() def RegisteredFlags(self): @@ -1375,13 +1375,13 @@ self.__RenderOurModuleFlags(module, helplist) self.__RenderModuleFlags('gflags', - _SPECIAL_FLAGS.FlagDict().values(), + list(_SPECIAL_FLAGS.FlagDict().values()), helplist) else: # Just print one long list of flags. self.__RenderFlagList( - self.FlagDict().values() + _SPECIAL_FLAGS.FlagDict().values(), + list(self.FlagDict().values()) + list(_SPECIAL_FLAGS.FlagDict().values()), helplist, prefix) return '\n'.join(helplist) @@ -1488,7 +1488,7 @@ """Returns: dictionary; maps flag names to their shortest unique prefix.""" # Sort the list of flag names sorted_flags = [] - for name, flag in fl.items(): + for name, flag in list(fl.items()): sorted_flags.append(name) if flag.boolean: sorted_flags.append('no%s' % name) @@ -1570,7 +1570,7 @@ flag_line_list = [] # Subset of lines w/o comments, blanks, flagfile= tags. try: file_obj = open(filename, 'r') - except IOError, e_msg: + except IOError as e_msg: raise CantOpenFlagFileError('ERROR:: Unable to open flagfile: %s' % e_msg) line_list = file_obj.readlines() @@ -1682,7 +1682,7 @@ from http://code.google.com/p/google-gflags """ s = '' - for flag in self.FlagDict().values(): + for flag in list(self.FlagDict().values()): if flag.value is not None: s += flag.Serialize() + '\n' return s @@ -1769,7 +1769,7 @@ try: return str(value) except UnicodeEncodeError: - return unicode(value) + return str(value) def _MakeXMLSafe(s): @@ -1883,7 +1883,7 @@ def Parse(self, argument): try: self.value = selfRefactoringTool: Files that were modified: RefactoringTool: ./tests/gflags_validators_test.py RefactoringTool: ./tests/gflags_unittest.py RefactoringTool: ./tests/gflags_helpxml_test.py RefactoringTool: ./tests/gflags_googletest.py RefactoringTool: ./tests/flags_modules_for_testing/module_foo.py RefactoringTool: ./tests/flags_modules_for_testing/module_baz.py RefactoringTool: ./tests/flags_modules_for_testing/module_bar.py RefactoringTool: ./setup.py RefactoringTool: ./gflags_validators.py RefactoringTool: ./gflags2man.py RefactoringTool: ./gflags.py .parser.Parse(argument) - except ValueError, e: # recast ValueError as IllegalFlagValue + except ValueError as e: # recast ValueError as IllegalFlagValue raise IllegalFlagValue("flag --%s=%s: %s" % (self.name, argument, e)) self.present += 1 @@ -2030,7 +2030,7 @@ return type.__call__(mcs, *args) -class ArgumentParser(object): +class ArgumentParser(object, metaclass=_ArgumentParserCache): """Base class used to parse and convert arguments. The Parse() method checks to make sure that the string argument is a @@ -2045,7 +2045,6 @@ and shared between flags. Initializer arguments are allowed, but all member variables must be derived from initializer arguments only. """ - __metaclass__ = _ArgumentParserCache syntactic_help = "" @@ -2296,7 +2295,7 @@ # a different module. So, we can't use _GetKeyFlagsForModule. # Instead, we take all flags from _SPECIAL_FLAGS (a private # FlagValues, where no other module should register flags). - [f.name for f in _SPECIAL_FLAGS.FlagDict().values()], + [f.name for f in list(_SPECIAL_FLAGS.FlagDict().values())], flag_values=_SPECIAL_FLAGS, key_flag_values=flag_values) @@ -2396,10 +2395,10 @@ if arg: doc = sys.modules["__main__"].__doc__ flags = str(FLAGS) - print doc or ("\nUSAGE: %s [flags]\n" % sys.argv[0]) + print(doc or ("\nUSAGE: %s [flags]\n" % sys.argv[0])) if flags: - print "flags:" - print flags + print("flags:") + print(flags) sys.exit(1) class HelpXMLFlag(BooleanFlag): """Similar to HelpFlag, but generates output in XML format.""" @@ -2426,10 +2425,10 @@ if arg: doc = sys.modules["__main__"].__doc__ flags = FLAGS.MainModuleHelp() - print doc or ("\nUSAGE: %s [flags]\n" % sys.argv[0]) + print(doc or ("\nUSAGE: %s [flags]\n" % sys.argv[0])) if flags: - print "flags:" - print flags + print("flags:") + print(flags) sys.exit(1) # ++ find ./ -name '*.py' + sed -i 's|#!/usr/bin/env python|#!/usr/bin/env python3|' ./tests/gflags_validators_test.py ./tests/gflags_unittest.py ./tests/gflags_helpxml_test.py ./tests/gflags_googletest.py ./tests/flags_modules_for_testing/module_foo.py ./tests/flags_modules_for_testing/module_baz.py ./tests/flags_modules_for_testing/module_bar.py ./tests/flags_modules_for_testing/__init__.py ./setup.py ./gflags_validators.py ./gflags2man.py ./gflags.py + CFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export CFLAGS + CXXFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export CXXFLAGS + FFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export FFLAGS + /usr/bin/python3 setup.py build --debug running build running build_py creating build creating build/lib copying gflags.py -> build/lib copying gflags_validators.py -> build/lib running egg_info writing python_gflags.egg-info/PKG-INFO writing dependency_links to python_gflags.egg-info/dependency_links.txt writing top-level names to python_gflags.egg-info/top_level.txt reading manifest file 'python_gflags.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' writing manifest file 'python_gflags.egg-info/SOURCES.txt' + popd ~/RPM/BUILD/python-module-gflags-2.0 ++ grep -Rl '#!.*python$' AUTHORS COPYING ChangeLog MANIFEST.in Makefile NEWS PKG-INFO README build debian gflags.py gflags2man.py gflags_validators.py python_gflags.egg-info setup.cfg setup.py tests ++ find ./ -name '*.py' + subst 's|#!.*python$|#!/usr/bin/python2.7|' build/lib/gflags_validators.py build/lib/gflags.py gflags.py gflags2man.py gflags_validators.py setup.py tests/gflags_validators_test.py tests/gflags_unittest.py tests/gflags_helpxml_test.py tests/gflags_googletest.py tests/flags_modules_for_testing/module_foo.py tests/flags_modules_for_testing/module_baz.py tests/flags_modules_for_testing/module_bar.py ./build/lib/gflags_validators.py ./build/lib/gflags.py ./tests/gflags_validators_test.py ./tests/gflags_unittest.py ./tests/gflags_helpxml_test.py ./tests/gflags_googletest.py ./tests/flags_modules_for_testing/module_foo.py ./tests/flags_modules_for_testing/module_baz.py ./tests/flags_modules_for_testing/module_bar.py ./tests/flags_modules_for_testing/__init__.py ./setup.py ./gflags_validators.py ./gflags2man.py ./gflags.py + CFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export CFLAGS + CXXFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export CXXFLAGS + FFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export FFLAGS + /usr/bin/python2.7 setup.py build --debug running build running build_py running egg_info writing python_gflags.egg-info/PKG-INFO writing top-level names to python_gflags.egg-info/top_level.txt writing dependency_links to python_gflags.egg-info/dependency_links.txt reading manifest file 'python_gflags.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' writing manifest file 'python_gflags.egg-info/SOURCES.txt' + exit 0 Executing(%install): /bin/sh -e /usr/src/tmp/rpm-tmp.50483 + umask 022 + /bin/mkdir -p /usr/src/RPM/BUILD + cd /usr/src/RPM/BUILD + /bin/chmod -Rf u+rwX -- /usr/src/tmp/python-module-gflags-buildroot + : + /bin/rm -rf -- /usr/src/tmp/python-module-gflags-buildroot + cd python-module-gflags-2.0 + pushd ../python3 ~/RPM/BUILD/python3 ~/RPM/BUILD/python-module-gflags-2.0 + CFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export CFLAGS + CXXFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export CXXFLAGS + FFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export FFLAGS + /usr/bin/python3 setup.py install --skip-build --root=/usr/src/tmp/python-module-gflags-buildroot --force running install running install_lib creating /usr/src/tmp/python-module-gflags-buildroot creating /usr/src/tmp/python-module-gflags-buildroot/usr creating /usr/src/tmp/python-module-gflags-buildroot/usr/lib creating /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3 creating /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages copying build/lib/gflags_validators.py -> /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages copying build/lib/gflags.py -> /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages byte-compiling /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags_validators.py to gflags_validators.cpython-38.pyc byte-compiling /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags.py to gflags.cpython-38.pyc running install_data creating /usr/src/tmp/python-module-gflags-buildroot/usr/bin copying gflags2man.py -> /usr/src/tmp/python-module-gflags-buildroot/usr/bin running install_egg_info running egg_info writing python_gflags.egg-info/PKG-INFO writing dependency_links to python_gflags.egg-info/dependency_links.txt writing top-level names to python_gflags.egg-info/top_level.txt reading manifest file 'python_gflags.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' writing manifest file 'python_gflags.egg-info/SOURCES.txt' Copying python_gflags.egg-info to /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/python_gflags-2.0-py3.8.egg-info running install_scripts + popd ~/RPM/BUILD/python-module-gflags-2.0 + pushd /usr/src/tmp/python-module-gflags-buildroot/usr/bin ~/tmp/python-module-gflags-buildroot/usr/bin ~/RPM/BUILD/python-module-gflags-2.0 ++ ls + for i in $(ls) + mv gflags2man.py gflags2man.py.py3 + popd ~/RPM/BUILD/python-module-gflags-2.0 + CFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export CFLAGS + CXXFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export CXXFLAGS + FFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -march=i586 -mtune=generic' + export FFLAGS + /usr/bin/python2.7 setup.py install --skip-build --root=/usr/src/tmp/python-module-gflags-buildroot --force running install running install_lib creating /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7 creating /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages copying build/lib/gflags.py -> /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages copying build/lib/gflags_validators.py -> /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages byte-compiling /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags.py to gflags.pyc byte-compiling /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags_validators.py to gflags_validators.pyc running install_data copying gflags2man.py -> /usr/src/tmp/python-module-gflags-buildroot/usr/bin running install_egg_info running egg_info writing python_gflags.egg-info/PKG-INFO writing top-level names to python_gflags.egg-info/top_level.txt writing dependency_links to python_gflags.egg-info/dependency_links.txt reading manifest file 'python_gflags.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' writing manifest file 'python_gflags.egg-info/SOURCES.txt' Copying python_gflags.egg-info to /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/python_gflags-2.0-py2.7.egg-info running install_scripts + /usr/lib/rpm/brp-alt Cleaning files in /usr/src/tmp/python-module-gflags-buildroot (auto) Verifying and fixing files in /usr/src/tmp/python-module-gflags-buildroot (binconfig,pkgconfig,libtool,desktop) Checking contents of files in /usr/src/tmp/python-module-gflags-buildroot/ (default) Compressing files in /usr/src/tmp/python-module-gflags-buildroot (auto) Adjusting library links in /usr/src/tmp/python-module-gflags-buildroot ./usr/lib: Verifying ELF objects in /usr/src/tmp/python-module-gflags-buildroot (arch=normal,fhs=normal,lfs=relaxed,lint=relaxed,rpath=normal,stack=normal,textrel=normal,unresolved=normal) Bytecompiling python modules in /usr/src/tmp/python-module-gflags-buildroot using /usr/bin/python2.7 unlink /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags.pyc unlink /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags_validators.pyc compile /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags.py compile /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags_validators.py Bytecompiling python modules with optimization in /usr/src/tmp/python-module-gflags-buildroot using /usr/bin/python2.7 -O compile /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags.py compile /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags_validators.py Bytecompiling python3 modules in /usr/src/tmp/python-module-gflags-buildroot using /usr/bin/python3 unlink /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/__pycache__/gflags.cpython-38.pyc unlink /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/__pycache__/gflags_validators.cpython-38.pyc compile /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags.py compile /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags_validators.py Bytecompiling python3 modules with optimization in /usr/src/tmp/python-module-gflags-buildroot using /usr/bin/python3 -O compile /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags.py compile /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags_validators.py Bytecompiling python3 modules with optimization-2 in /usr/src/tmp/python-module-gflags-buildroot using /usr/bin/python3 -OO compile /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags.py compile /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags_validators.py Hardlinking identical .pyc and .opt-?.pyc files './usr/lib/python3/site-packages/__pycache__/gflags_validators.cpython-38.opt-1.pyc' => './usr/lib/python3/site-packages/__pycache__/gflags_validators.cpython-38.pyc' Hardlinking identical .pyc and .pyo files './usr/lib/python2.7/site-packages/gflags_validators.pyo' => './usr/lib/python2.7/site-packages/gflags_validators.pyc' Processing files: python-module-gflags-2.0-alt2.1.3 Executing(%doc): /bin/sh -e /usr/src/tmp/rpm-tmp.62059 + umask 022 + /bin/mkdir -p /usr/src/RPM/BUILD + cd /usr/src/RPM/BUILD + cd python-module-gflags-2.0 + DOCDIR=/usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python-module-gflags-2.0 + export DOCDIR + rm -rf /usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python-module-gflags-2.0 + /bin/mkdir -p /usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python-module-gflags-2.0 + cp -prL AUTHORS ChangeLog NEWS README /usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python-module-gflags-2.0 + chmod -R go-w /usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python-module-gflags-2.0 + chmod -R a+rX /usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python-module-gflags-2.0 + exit 0 Finding Provides (using /usr/lib/rpm/find-provides) Executing: /bin/sh -e /usr/src/tmp/rpm-tmp.M5IBO7 find-provides: running scripts (alternatives,debuginfo,lib,pam,perl,pkgconfig,python,python3,shell) Finding Requires (using /usr/lib/rpm/find-requires) Executing: /bin/sh -e /usr/src/tmp/rpm-tmp.Hd5eu4 find-requires: running scripts (cpp,debuginfo,files,lib,pam,perl,pkgconfig,pkgconfiglib,python,python3,rpmlib,shebang,shell,static,symlinks,systemd-services) python.req: /usr/src/tmp/python-module-gflags-buildroot/usr/bin/gflags2man.py: skipping sys python.req: /usr/src/tmp/python-module-gflags-buildroot/usr/bin/gflags2man.py: hiding gflags, which SEEMS TO BE SELF-SATISFIED python.req: /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags.py: skipping sys /usr/lib/rpm/python.req.py: /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags.py: line=399 IGNORE (for REQ=slight and deep=8) module=fcntl /usr/lib/rpm/python.req.py: /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags.py: line=404 IGNORE (for REQ=slight and deep=8) module=termios python.req: /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags.py: hiding gflags_validators, which SEEMS TO BE SELF-SATISFIED shebang.req.files: executable script /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags.py is not executable shebang.req.files: executable script /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python2.7/site-packages/gflags_validators.py is not executable Provides: python2.7-module-gflags = 2.0-alt2.1.3, python2.7(gflags), python2.7(gflags_validators) Requires: python = 2.7, /usr/bin/python2.7, /usr/lib/python2.7/site-packages, python-modules Processing files: python3-module-gflags-2.0-alt2.1.3 Executing(%doc): /bin/sh -e /usr/src/tmp/rpm-tmp.48750 + umask 022 + /bin/mkdir -p /usr/src/RPM/BUILD + cd /usr/src/RPM/BUILD + cd python-module-gflags-2.0 + DOCDIR=/usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python3-module-gflags-2.0 + export DOCDIR + rm -rf /usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python3-module-gflags-2.0 + /bin/mkdir -p /usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python3-module-gflags-2.0 + cp -prL AUTHORS ChangeLog NEWS README /usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python3-module-gflags-2.0 + chmod -R go-w /usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python3-module-gflags-2.0 + chmod -R a+rX /usr/src/tmp/python-module-gflags-buildroot/usr/share/doc/python3-module-gflags-2.0 + exit 0 Finding Provides (using /usr/lib/rpm/find-provides) Executing: /bin/sh -e /usr/src/tmp/rpm-tmp.8fSPA8 find-provides: running scripts (alternatives,debuginfo,lib,pam,perl,pkgconfig,python,python3,shell) Finding Requires (using /usr/lib/rpm/find-requires) Executing: /bin/sh -e /usr/src/tmp/rpm-tmp.Pelhj6 find-requires: running scripts (cpp,debuginfo,files,lib,pam,perl,pkgconfig,pkgconfiglib,python,python3,rpmlib,shebang,shell,static,symlinks,systemd-services) python3.req: /usr/src/tmp/python-module-gflags-buildroot/usr/bin/gflags2man.py.py3: skipping sys python3.req: /usr/src/tmp/python-module-gflags-buildroot/usr/bin/gflags2man.py.py3: skipping time python3.req: /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags.py: skipping sys /usr/lib/rpm/python3.req.py: /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags.py: line=399 IGNORE (for REQ=slight and deep=8) module=fcntl /usr/lib/rpm/python3.req.py: /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags.py: line=404 IGNORE (for REQ=slight and deep=8) module=termios shebang.req.files: executable script /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags.py is not executable shebang.req.files: executable script /usr/src/tmp/python-module-gflags-buildroot/usr/lib/python3/site-packages/gflags_validators.py is not executable find-requires: FINDPACKAGE-COMMANDS: python3 Provides: python3(gflags), python3(gflags_validators) Requires: /usr/bin/env, /usr/lib/python3/site-packages, python3, python3(cgi) < 0, python3(getopt) < 0, python3(os) < 0, python3(re) < 0, python3(stat) < 0, python3(string) < 0, python3(struct) < 0 Wrote: /usr/src/RPM/RPMS/noarch/python-module-gflags-2.0-alt2.1.3.noarch.rpm Wrote: /usr/src/RPM/RPMS/noarch/python3-module-gflags-2.0-alt2.1.3.noarch.rpm 19.63user 1.56system 0:23.80elapsed 89%CPU (0avgtext+0avgdata 32008maxresident)k 0inputs+0outputs (0major+227755minor)pagefaults 0swaps 31.69user 8.76system 0:41.77elapsed 96%CPU (0avgtext+0avgdata 113872maxresident)k 0inputs+0outputs (0major+674689minor)pagefaults 0swaps