Looking back at Bugzilla and BMO in 2017

Dave Miller justdave at bugzilla.org
Fri Jan 5 06:01:58 UTC 2018


Reposted from Dylan's tumblr
<https://dylanwh.tumblr.com/post/169334782317/looking-back-at-bugzilla-and-bmo-in-2017>
with permission.

-----8<-----

  *


        Looking back at Bugzilla and BMO in 2017
        <https://dylanwh.tumblr.com/post/169334782317/looking-back-at-bugzilla-and-bmo-in-2017>


      Looking Back

    Recently in the Bugzilla Project meeting
    <http://t.umblr.com/redirect?z=https%3A%2F%2Fair.mozilla.org%2Fbugzilla-project-meeting-20180103%2F&t=ZjExOTA3ZGFlOWY1MzM1OWU1OTEwOGIwNjViYWEzM2JmOGZkMjY3Nyx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>,
    Gerv informed us that he would be resigning, and it was pretty clear
    that my lack of technical leadership was the cause. While I am sad
    to see Gerv go, it did make me realize I need to write more about
    the things I do.

    As is evident in this post, all of the things I’ve accomplished have
    been related to the BMO codebase and not upstream Bugzilla – which
    is why upstream must be rebased on BMO. See Bug 1427884
    <http://t.umblr.com/redirect?z=https%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1427884&t=ZmQ5ODEyZWUwMDY1ZTRiNzZlMzkwMDM3OWE3YjA3NmMxMWEzYjE1Nyx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
    for one of the blockers to this.


        Accessibility Changes

    In 2017, we made over a dozen a11y changes, and I’ve heard from a
    well-known developer that using BMO with a screen reader is far
    superior to other bugzillas. :-)


        Infrastructure Changes

    BMO is quite happy to use carton
    <http://t.umblr.com/redirect?z=https%3A%2F%2Fmetacpan.org%2Frelease%2FCarton&t=MWI1NmFmYTlhMmM2NjI4OTdiYzA4ZDdhZmRjMDhhODVlM2FlNTVlZix4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
    to manage its perl dependencies, and Docker handle its system-level
    dependencies.

    We’re quite close to being able to run on Kubernetes.

    While the code is currently turned off in production, we also
    feature a very advanced query translator that allows the use of
    ElasticSearch to index all bugs and comments.


        Performance Changes

    I sort of wanted to turn each of these into a separate blog post,
    but I never got time for that – and I’m even more excited about
    writing about future work. But rather than just let them hide away
    in bugs, I thought I’d at least list them and give a short summary.


          February

      o Bug 1336958
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1336958&t=YmQ3YjBkNjhkZGJjZGNiMDM3NzUxNDNkZTBiYzNiNjVkNmMxNTZmOSx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - HTML::Tree requires manual memory management or it leaks
        memory. I discovered this while looking at some unrelated code.
      o Bug 1335233
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1335233&t=NGQwZTBlNTljMTQ5OTA1OGVjMmU5NDYyY2YyNGQwODY4NTlmMjEzYSx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - I noticed that the job queue runner wasn’t calling the
        end-of-request cleanup code, and a result it was also leaking
        memory.


          March

      o Bug 1345181
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1345181&t=YjZlYmE5ODFmY2I0Y2I3ZmYwYjRiYjFmOGEzMTEzOWZiZWRlNzJlOSx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - make html_quote() about five times faster.
      o Bug 1347570
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1347570&t=OTJlMzJjM2FhMTZlMWQyZjBlYzY4NzAzZDc4YWFkMDQ3NzNiY2FlMix4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - make it so apache in the dev/test environments didn’t need to
        restart after every request (by enforcing a minimum memory limit)
      o Bug 1350466
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1350466&t=Y2M3YWRiYTc4OTVkMTVmMzZhMTdmNGVjNzBiODZlZWQxNjcyODlhMix4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - switched JSON serialization to JSON::XS, which is nearly 1000
        times faster.
      o Bug 1350467
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1350467&t=OWY3MGMzNzUxN2YyODIwYzIzNTQ4YzQ3MzMxNjZlOGY2NDU0MmZlNyx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - caused more modules (those provided by optional features) to
        be preloaded at apache startup.
      o Bug 1351695
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1351695&t=ZWQ0ZjY0ZWM5NTk3NmY3NjZmNGZhNWQ1ZDVkOWE0MDMyOTg1MjVhZSx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - Pre-load “.htaccess” files and allow apache to ignore them


          April

      o Bug 1355127
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1355127&t=MTk4M2Y4NDE0ZDQ3MzA3NDk0YWFiMTQxZTMzM2ZiOGJjZWJkY2NmMSx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - rewrote a template that is in a tight loop to Perl.
      o Bug 1355134
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1355134&t=MjJlMjM2MmU3MTA1MTY5MjgzZTNiNTQxYmNiMDkwNjZmMmI0MWQ5OSx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - fetch all group at once, rather than row-at-a-time.
      o Bug 1355137
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1355137&t=ZmU5OTExOGU1NDljYmY3N2QzOTAyMDRlNjUzYzYzZmUwODQyYzFmYix4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - Cache objects that represent bug fields.
      o Bug 1355142
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1355142&t=MGM0NTdmYTM1NjVjMWEyMDcyNjZhMTI4MjU5Yzg1ZmM3NDhmMzk0MCx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - Instead of using a regular expression to “trick” Perl’s string
        tainting system, use a module to directly flip the “taint” bit.
        This was hundreds of times faster.
      o Bug 1352264
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1352264&t=NjllNDdkNDU0MTJmZDU4ODUyMDNiYjEzYTMyYWEzYzc1NzZlYjYxMSx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - Compile all templates and store them in memory. This actually
        saved both CPU time and RAM, because the memory used by
        templates is shared by all workers on a given node.


          May

      o Bug 1362151
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1362151&t=NDlkMjQyNDVlNGRiZDRjY2RlN2Q5MTk5OWZmZTM1ZjQ5YzNlMTBhOSx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - Cache bzapi configuration API, making ‘bz export’ commands (on
        developer machines) faster by 2-5 seconds.
      o Bug 1352907
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1352907&t=MzFhOTQ0OTNmN2FlYTkwZTNkY2RkZTc3OGQ2YTFkZDQ3YzE3NWI5NSx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - Rewrite the Bugzilla extension loading system. The previous
        one was incredibly inefficient.


          June

      o Bug 1355169
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1355169&t=YWQyN2IwNDM3MGNiYmQyYjVlYWZiYjM3MzhhZGEyODFmMTY1NWJhMyx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - Mentored intern to implement token-bucket based rate limiting.
        Not strictly a performance thing but it reduced API abuse.


          December

      o Bug 1426963
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1426963&t=NmUyMTFmNGJhNWZhZTE4Y2Q1NDNlYzFlYzY3YmQ2YzZlZjIyYmE1OCx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>
        - Use a hash lookup to determine group membership, rather than
        searching an unsorted list. Bug 1427230
        <http://t.umblr.com/redirect?z=http%3A%2F%2Fbugzilla.mozilla.org%2Fshow_bug.cgi%3Fid%3D1427230&t=OWI1MThmYzQ0ZGFkZjAzNzc1NjFmYTNlNTJiNTU5ZWIyYmIxMjg4OSx4elpxMDNEUQ%3D%3D&b=t%3A0Pgjf2A6DvxxDbdfUX1AxA&p=https%3A%2F%2Fdylanwh.tumblr.com%2Fpost%2F169334782317%2Flooking-back-at-bugzilla-and-bmo-in-2017&m=1>


        Developer Experience Changes

    My favorite communities optimize for fun. Frequently fun means being
    able to get things done. So in 2017 I did the following:

      o Made a vagrant development environment setup that closely mapped
        to BMO production. ** I tested installing it on various machines
        – Linux, OSX, Windows ** I wrote a README explaining how to use
        it. ** This dev environment has been tested by people with
        little or no experience with Bugzilla development.
      o I changed to a pull-request based workflow. We use Bugzilla to
        track bugs and tasks, but not do code review.
      o I made it so the entire test suite could run against pull
        requests. This isn’t trivial, you have to work a bit harder to
        build docker images and run them without having any dockerhub
        credentials. (Pull requests don’t get any dockerhub credentials,
        I have to say to make sure my friend ulfr doesn’t have a heart
        attack)
      o I made sure that I understood how to use Atom and Visual Studio
        Code. I actually rather like the later now – and more
        importantly it is easy to help out new-comers with these editors.
      o I adopted Perl::Critic for code linting and Perl::Tidy for
        code-formatting, using the PBP ruleset for the later. I also
        made it a point to not make code style a part of code review –
        let the machine do that.


        Numbers

    In the last year, we had almost 500 commits to the BMO repo, from 20
    different people. Some people were new, and some were returning
    contributors (such as Sebastin Santy).


-----8<-----

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.bugzilla.org/pipermail/developers/attachments/20180105/6bb70c55/attachment.html>


More information about the developers mailing list