On Tue, 7 Nov 2023 at 15:36, Martin Jambor <mjam...@suse.cz> wrote: > > Hello, > > On Tue, Nov 07 2023, Maxim Kuvyrkov wrote: > n>> On Nov 6, 2023, at 21:19, Christophe Lyon <christophe.l...@linaro.org> > wrote: > >> > >> Hi! > >> > >> On Mon, 6 Nov 2023 at 18:05, Martin Jambor <mjam...@suse.cz> wrote: > >>> > >>> Hello, > >>> > >>> I have inherited Martin Liška's buildbot script that checks that all > >>> sorts of autotools generated files, mainly configure scripts, were > >>> re-generated correctly when appropriate. While the checks are hopefully > >>> useful, they report issues surprisingly often and reporting them feels > >>> especially unproductive. > >>> > >>> Could such checks be added to our server side push hooks so that commits > >>> introducing these breakages would get refused automatically. While the > >>> check might be a bit expensive, it only needs to be run on files > >>> touching the generated files and/or the files these are generated from. > >>> > >>> Alternatively, Maxim, you seem to have an infrastructure that is capable > >>> of sending email. Would you consider adding the check to your buildbot > >>> instance and report issues automatically? The level of totally > >> > >> After the discussions we had during Cauldron, I actually thought we > >> should add such a bot. > >> > >> Initially I was thinking about adding this as a "precommit" check, to > >> make sure the autogenerated files were submitted correctly, but I > >> realized that the policy is actually not to send autogenerated files > >> as part of the patch (thus making pre-commit check impracticable in > >> such cases, unless we autogenerate those files after applying the > >> patch) > >> > >> I understand you mean to run this as a post-commit bot, meaning we > >> would continue to "accept" broken commits, but now automatically send > >> a notification, asking for a prompt fix? > > My thinking was that ideally bad commits would get refused early, like > when you get your ChangeLog completely wrong, but if there are drawbacks > to that approach, a completely automated notification system would be > great too. > Well, making such checks in a precommit-CI means that authors should include regenerated files in their patch submissions, so it seems this would imply a policy change (not impossible, but will likely take some time to get consensus?)
> >> > >> We can probably implement that, indeed. Is that the general agreement? > > > > [CC: Siddhesh, Carlos] > > > > Hi Martin, > > > > I agree with Christophe, and we can add various source-level checks > > and wrap them up as a post-commit job. The job will then send out > > email reports to developers whose patches failed it. > > Thanks, automating this would be a huge improvement. > > > > > Where the current script is located? These checks would be useful for > > all GNU Toolchain projects -- binutils/GDB, GCC, Glibc and, maybe, > > Newlib -- so it would be useful to put it in a separate "gnutools" > > repo. > > The test consists of running a python script that I'm pasting below in a > directory with a current master branch and subsequently checking that > "git diff" does not actually produce any diff (which currently does). Great, I was thinking about writing something like that :-) > You need to have locally built autotools utilities of exactly the right > version. The script (written by Martin Liška) is: > > ------------------------------ 8< ------------------------------ > #!/usr/bin/env python3 > > import os > import subprocess > from pathlib import Path > > AUTOCONF_BIN = 'autoconf-2.69' > AUTOMAKE_BIN = 'automake-1.15.1' > ACLOCAL_BIN = 'aclocal-1.15.1' > AUTOHEADER_BIN = 'autoheader-2.69' > > ENV = f'AUTOCONF={AUTOCONF_BIN} ACLOCAL={ACLOCAL_BIN} AUTOMAKE={AUTOMAKE_BIN}' > > config_folders = [] > > for root, _, files in os.walk('.'): > for file in files: > if file == 'configure': > config_folders.append(Path(root).resolve()) > > for folder in sorted(config_folders): > print(folder, flush=True) > os.chdir(folder) > configure_lines = open('configure.ac').read().splitlines() > if any(True for line in configure_lines if > line.startswith('AC_CONFIG_HEADERS')): > subprocess.check_output(f'{ENV} {AUTOHEADER_BIN} -f', shell=True, > encoding='utf8') > # apparently automake is somehow unstable -> skip it for gotools > if (any(True for line in configure_lines if > line.startswith('AM_INIT_AUTOMAKE')) > and not str(folder).endswith('gotools')): > subprocess.check_output(f'{ENV} {AUTOMAKE_BIN} -f', > shell=True, encoding='utf8') > subprocess.check_output(f'{ENV} {AUTOCONF_BIN} -f', shell=True, > encoding='utf8') > > ------------------------------ 8< ------------------------------ Nice, thanks for sharing. > > > I think Siddhesh and Carlos are looking into creating such a repo on > > gitlab? > > I guess this particular script may be even put into gcc's contrib > directory. But it can be put anywhere where it makes most sense and > suits you best. Indeed, but as Maxim pointed out to me, we would probably want to run the same kind of checks for binutils and gdb, so it's better if the CI can clone a very small repo with such scripts rather than having to clone the whole GCC when checking if a binutils patch is well-formed. I'm happy with Carlos' proposal of using a new gitlab repo with such utilities/checkers, which we can then use from various CI implementations. Thanks, Christophe > > Thanks, > > Martin