yellow team mailing list archive
-
yellow team
-
Mailing list archive
-
Message #02096
Various small cleanups (issue 7005044)
Reviewers: mp+141022_code.launchpad.net,
Message:
Please take a look.
Description:
Various small cleanups
This branch has a little for everyone. I did it during spare moments
today to see if I could address various issues I saw and had heard
about. I think that landing this branch would be fine, but I also would
be happy enough if people wanted to extract bits from it on a piecemeal
basis instead. I'm sorry that everything is mixed together, but they
are small changes. I can extract, or ask other people to, if necessary.
I'm going to fully explain the changes. This will help me remember. It
will also probably be painful to read. Sorry.
For Nicola, and for those with a masochistic enjoyment of Makefile
churn, I addressed bug 1092199: "Makefile build target is misnamed."
See the bug for rationale and for the plan, which I followed except that
I used "build-shared" instead of "build-common" as the new name for the
former "build" directory. This "build-shared" choice, like a couple of
other choices in this branch, was fairly arbitrary. I'd rather not
change it, but that's because of time and inertia. If I'd reread the
bug before starting I probably would have used build-common. Fixes for
this bug account for the vast majority of the Makefile changes. The two
exceptions are the change to the JSFILES variable definition, and the
removal of the skin asset Make dependencies for build-prod and
build-devel. I'll explain those in a moment. This bug also accounts
for many of the changes in bin/merge-files, and various other places
where you see s/build/build-shared/.
Thanks to the diagnosis and discussion from Nicola, Francesco and Kapil,
I addressed one of the remaining parts of bug 1083920, "Charm should
serve the GUI assets over HTTPS". Francesco identified two insecure
sources we were having trouble with when we served over HTTPS. One
insecure connection was the charm store. Kapil is working on getting a
cert for the charm store, so we can simply use HTTPS for our charm store
URLs. The other insecure connection is that we were still relying on a
number of files from the Yahoo CDN. In prod, we relied on the HTTP-only
CDN for three Gallery files, and in debug (and devel) we relied on the
CDN for many files in addition. I fixed the way we serve our files in
devel, debug and prod, so that all YUI files are served locally. The
main step for this was to get the gallery files stored locally. I could
have done this many ways. One choice could have been to use the npm
yui-gallery package, but it is quite old so I rejected it. I also could
have gotten all the gallery files from git as part of the build process.
That would have been fine, as would have other approaches, but I went
for an explicit and simple approach: I downloaded the files we needed
into app/assets/javascripts and told the debug modules file where to
find them and told the minifier to include them. This also required
some tweaks to the Makefile's JSFILES calculation, to exclude those
files.
With help from Benji, I updated the reviewer documentation and the
release documentation to reflect the current state of things. Hopefully
those changes are self-explanatory, and if they are not, we should
probably fix them so they are!
I removed some unnecessarily duplicated and ignored topology "requires"
in the modules-debug.js file, as requested by a comment at the top of
that file and as blessed by Ben.
More valuably, I seem to have fixed the errors we saw in ``make
test-prod`` in Ben's recently landed branch. I believe it was because
of the fake console missing a "debug" call. In any case, I was having
trouble with prod, and now it is working for me, and the prod tests seem
fine too.
I tweaked Benji's Makefile change that had switched back from linking to
copying YUI files into the build directories. The old symlinks had put
the skin file assets in the wrong place. When Benji fixed the assets,
he didn't notice that the Makefile said that it depended on the wrong
location of those files. This meant that every time you ran make, the
Makefile would rerun the linking code, in the vain attempt to create
those incorrectly-placed files. Rather than include all skin asset
locations, I simply removed those two dependencies ("night" and "sam").
Now the Makefile is as quiet as desired on repeated runs of "make,"
"make prod," "make debug," and "make devel."
OK, that's it. As I said, landing this seems OK, but feel free to steal
from it instead. Please poke around both at the Makefile and the app to
make sure nothing seems to have regressed. Thank you!
https://code.launchpad.net/~gary/juju-gui/grabbag/+merge/141022
(do not edit description out of merge proposal)
Please review this at https://codereview.appspot.com/7005044/
Affected files:
M .bzrignore
M Makefile
A [revision details]
A app/assets/javascripts/gallery-ellipsis-debug.js
A app/assets/javascripts/gallery-ellipsis.js
A app/assets/javascripts/gallery-markdown-debug.js
A app/assets/javascripts/gallery-markdown.js
A app/assets/javascripts/gallery-timer-debug.js
A app/assets/javascripts/gallery-timer.js
M app/modules-debug.js
M app/views/utils.js
M bin/merge-files
M docs/process.rst
M grunt.js
M lib/server.js
M lib/templates.js
--
https://code.launchpad.net/~gary/juju-gui/grabbag/+merge/141022
Your team Juju GUI Hackers is requested to review the proposed merge of lp:~gary/juju-gui/grabbag into lp:juju-gui.
References