Attached is what I see for Pharo 7 images in PharoLauncher. I presume the top one is the latest, but Its a bit hard to tell :P Anyone else seeing this? Loading ConfigurationOfPharoLauncher-ChristopheDemarey.53 (latest) and doing "ConfigurationOfPharoLauncher loadDevelopment" which loads PharoLauncher-Core-ChristopheDemarey.116 (latest) This is with Pharo builds 60486 and 60510, and same VM for both... Win32 built on May 31 2017 03:09:04 GMT Compiler: 5.4.0 VMMaker versionString VM: 201705310241 CoInterpreter VMMaker.oscog-eem.2231 uuid: de62947a-7f40-4977-a232-e06a3a80c939 May 31 2017 (but btw, does that look strange? The 60510 image was lauched from the original 60486-PharoLauncher which said it was downloading the matching VM, so I kind of expect each image to have a different VM ?? ) cheers -ben PharoLauncher-Pharo7.png (125K) Download Attachment |
Hi Ben,
reason is that for Pharo 7 currently an sha git hash is used in the file name
instead of a (more clear) build number.
See http://files.pharo.org/image/70/ This problem (which has more side effects on different sides, not only the Launcher now) was discussed
already yesterday on Discord #iceberg channel with Esteban and Pavel. The current sha based image file name scheme is not only confusing but has some downsides.
One can not easily remember the SHA or see which image is the latest, or sort from recent images to older in a folder.
If I understood correctly the reason to (initially) choose sha's in the image name has something to do with Travis and a discussion between Pavel, Esteban and Guille. I would vote for using Build numbers again. We would have several BENEFITS when keeping/returning to build numbers for Pharo 7: - we do not change image file names, about box behavior, ... compared to previous Pharo version < 7 (as we used image build number already in the past) - we tag each release as before and see it in Git (we can easily reproduce) - the build number easily tells you which image is more recent (as before) - we can easily sort when we have several images in a directory - a build number is more readable and recognizable by a human (compared to the shas) - Pharo is not an "aliens" compared to the rest of the software world as often software follows a MAJOR.MINOR.PATCH/BUILDNUMBER scheme (see semver.org) - we do not change the order in Launcher (higher numbers at the top to download more recent) According to the discussion with Esteban and Pavel it is technically possible to have build numbers again - it means to tag each commit again with a build number (we already did this for Pharo 6, see https://github.com/pharo-project/pharo/releases) The outcome from yesterday was that Pavel will discuss again with Guile on that topic. It would be good if others could comment on that topic too. Maybe we can return to the known build number scheme
or (if there are problems with that) at least know the arguments why we need to be exotic/different on this corner in the future.
Thanks T.
Gesendet: Donnerstag, 03. August 2017 um 15:41 Uhr
Von: "Ben Coman" <[hidden email]> An: "Pharo Development List" <[hidden email]> Betreff: [Pharo-dev] PharoLauncher - uninformative Pharo7 template names Attached is what I see for Pharo 7 images in PharoLauncher.
I presume the top one is the latest, but Its a bit hard to tell :P
Anyone else seeing this?
Loading ConfigurationOfPharoLauncher-ChristopheDemarey.53 (latest)
and doing "ConfigurationOfPharoLauncher loadDevelopment" which loads PharoLauncher-Core-ChristopheDemarey.116 (latest)
This is with Pharo builds 60486 and 60510, and same VM for both...
Win32 built on May 31 2017 03:09:04 GMT Compiler: 5.4.0 VMMaker versionString VM: 201705310241
CoInterpreter VMMaker.oscog-eem.2231 uuid: de62947a-7f40-4977-a232-e06a3a80c939 May 31 2017
(but btw, does that look strange? The 60510 image was lauched from the original 60486-PharoLauncher which said it was downloading the matching VM, so I kind of expect each image to have a different VM ?? )
cheers -ben
|
On Fri, Aug 4, 2017 at 3:22 PM, Torsten Bergmann <[hidden email]> wrote:
Annotating build-commits with tags "seems" the right way to go, but I haven't played with them much. There does seem to some potential confusion in how tags operate to pay attention to... The example here by joshtkling that has two fetch lines might be useful (but I'm not sure if thats relevant to libgit or just to command-line git)... cheers -ben
|
In reply to this post by Torsten Bergmann
Hi torsten
Yes it sounds good to have MAJOR.MINOR.PATCH/BUILDNUMBER scheme On Fri, Aug 4, 2017 at 9:22 AM, Torsten Bergmann <[hidden email]> wrote: > Hi Ben, > > reason is that for Pharo 7 currently an sha git hash is used in the file > name > instead of a (more clear) build number. > > See http://files.pharo.org/image/70/ > > This problem (which has more side effects on different sides, not only the > Launcher now) was discussed > already yesterday on Discord #iceberg channel with Esteban and Pavel. > > The current sha based image file name scheme is not only confusing but has > some downsides. > One can not easily remember the SHA or see which image is the latest, or > sort from recent > images to older in a folder. > > If I understood correctly the reason to (initially) choose sha's in the > image name has something > to do with Travis and a discussion between Pavel, Esteban and Guille. > > I would vote for using Build numbers again. > > We would have several BENEFITS when keeping/returning to build numbers for > Pharo 7: > - we do not change image file names, about box behavior, ... compared to > previous Pharo version < 7 > (as we used image build number already in the past) > - we tag each release as before and see it in Git (we can easily reproduce) > - the build number easily tells you which image is more recent (as before) > - we can easily sort when we have several images in a directory > - a build number is more readable and recognizable by a human (compared to > the shas) > - Pharo is not an "aliens" compared to the rest of the software world as > often software > follows a MAJOR.MINOR.PATCH/BUILDNUMBER scheme (see semver.org) > - we do not change the order in Launcher (higher numbers at the top to > download more recent) > > According to the discussion with Esteban and Pavel it is technically > possible to have build numbers again - > it means to tag each commit again with a build number (we already did this > for Pharo 6, > see https://github.com/pharo-project/pharo/releases) > > The outcome from yesterday was that Pavel will discuss again with Guile on > that topic. It would be good if others > could comment on that topic too. Maybe we can return to the known build > number scheme > or (if there are problems with that) at least know the arguments why we need > to be exotic/different on > this corner in the future. > > Thanks > T. > > Gesendet: Donnerstag, 03. August 2017 um 15:41 Uhr > Von: "Ben Coman" <[hidden email]> > An: "Pharo Development List" <[hidden email]> > Betreff: [Pharo-dev] PharoLauncher - uninformative Pharo7 template names > > Attached is what I see for Pharo 7 images in PharoLauncher. > I presume the top one is the latest, but Its a bit hard to tell :P > Anyone else seeing this? > > Loading ConfigurationOfPharoLauncher-ChristopheDemarey.53 (latest) > and doing "ConfigurationOfPharoLauncher loadDevelopment" > which loads PharoLauncher-Core-ChristopheDemarey.116 (latest) > > This is with Pharo builds 60486 and 60510, and same VM for both... > Win32 built on May 31 2017 03:09:04 GMT Compiler: 5.4.0 VMMaker > versionString VM: 201705310241 > CoInterpreter VMMaker.oscog-eem.2231 uuid: > de62947a-7f40-4977-a232-e06a3a80c939 May 31 2017 > > (but btw, does that look strange? The 60510 image was lauched from the > original 60486-PharoLauncher which said it was downloading the matching VM, > so I kind of expect each image to have a different VM ?? ) > > cheers -ben |
Hi, I created an issue: I propose to keep both the sha and add the build number. Also, to follow semantic version conventions, we should use $- instead of $/. Something like: {Major}.{Minor}.{Patch}-sha.{sha}.build.{buildnumber} What do you think? I'll propose a pull request in some minutes. On Sat, Aug 5, 2017 at 6:17 PM, Stephane Ducasse <[hidden email]> wrote: Hi torsten
|
I made a PR
https://github.com/pharo-project/pharo/pull/185 this PR adds a script that will rename built archives accordingly. I propose the following file names for the zip: Pharo${IMAGE_KIND}-7.0.0-arch.32bit.sha.${HASH}.build.${BUILD_NUMBER}.zip Where: IMAGE_KIND is the built product (core image, image with monticello, image with metacello, full image...) HASH is the commit hash BUILD_NUMBER is the build number set by jenkins, or "nobuildnumber" if not available Moreover, this only makes part of a "prepare for upload" script and not the main build process. That is because of simplicity right now. However, if we put the build number by default in the main archives, there may be several drawbacks: - PR's builds will have build numbers conflicting with the main builds (which may be confusing) - when building locally, we do not necessarily have a build number available so it does not make much sense Once the PR is accepted/integrated, we should change the build process to use this script. Guille On Sun, Aug 6, 2017 at 9:05 AM, Guillermo Polito <[hidden email]> wrote:
|
About tagging... It looks super ackward to me to tag EVERY commit with "build information". Building does not mean releasing... I prefer the other way around: we tag builds with commit information. Like that we know how to reproduce the build. I'm ok with tagging build artifacts by explicitly saying "this is BUILD #X", which is ~= from "this is RELEASE #X". Moreover, before we needed to store ALL versions of the image because that was the way we versionned the system. Now, every commit in the #development branch should be buildable (delta some bugs of course ;)). This means that we can rebuild all images by just iterating the git history and building from scratch. No need to store all images. On Sun, Aug 6, 2017 at 9:40 AM, Guillermo Polito <[hidden email]> wrote:
|
In reply to this post by Ben Coman
Hi Guille,
Thanks for caring. I would vote to have the build number BEFORE the sha in the image name as this allows for easy sorting if we have several image files or image file Archives in a single/the same folder (sort from older to more recent Images) as it is for instance on files.pharo.org Thanks T. Am 06.08.2017, 09:40, Guillermo Polito <[hidden email]> schrieb:
|
In reply to this post by Guillermo Polito
On Sun, Aug 6, 2017 at 3:45 PM, Guillermo Polito <[hidden email]> wrote:
I'm not sure which comment your responding to, and not sure what you mean by "build information", but obviously someone may do several commits before doing a pull request, as they work through developing and testing a fix for an Issue. Its only the successful builds that are uploaded to files.pharo.org that are important to tag.
I'd imagine that tagging a commit as BUILD#X would be done as part of the CI immediately before the upload to files.pharo.org.
I don't understand why you'd need to iterate git history. Shouldn't you be able to rebuild an image from a single git commit?
Do you mean on files.pharo.com? That might be a good later goal, but for now these resultant images are useful to work with PharoLauncher without expending effort on redeveloping that to also rebuild images on the fly. cheers -ben
+1 to Torsten's suggestion to put the BUILD_NUMBER first, since it is more sortable than HASH. By "arch", do you mean Win/Linux/Mac? Or were labelling the bit-ness field? Also, is it important to prepend these with the numbers with "build." and "sha." fieldname strings? This bulks out the name increases the chance some interface needs to mangle the name to fit into a thin column. While we are discussion version naming (and I ask this from a position of ignorance) could you discuss with your team, without insider knowledge, how do we distinguish between the released 7.0.0 and all the 7.0.0 development builds heading towards that release? Can we add something to distinguish the development phase i.e. alpha/beta/rc/release (which coincidentally sort well with build numbers.) Pharo-${IMAGE_KIND}${BITNESS}-7.0.0-alpha.${BUIL Pharo-${IMAGE_KIND}${BITNESS}-7.0.0-beta.${BUIL Pharo-${IMAGE_KIND}${BITNESS}-7.0.0-rc.${BUIL Pharo-${IMAGE_KIND}${BITNESS}-7.0.0-release.${BUIL beta might be the defined point to ask applications to test-port to the new version, this perhaps being the optimum point to get fixes into the the next release. or if you don't want to be that sophisticated, maybe just phases dev/rel or for a more continuous release process, maybe '#' for the patch number... Pharo-${IMAGE_KIND}${BITNESS}-7.0.#-${BUIL (since '#' sorts before '0') cheers -ben
|
On Sun, Aug 6, 2017 at 5:46 PM, Ben Coman <[hidden email]> wrote:
yours :P. Yes, too early, I did not want to properly quote...
In this particular case I mean build number.
But then, why not just going through the files in files.pharo.org and get the corresponding hash from there (since they have the hash they correspond to)? I do not see the practical usecase. It's just redundance, no?
That's what I wanto to avoid. Why is that required? The generated file already has a pointer to the git commit it was generated from. Why do we need the backpointer from git to the build?
Yes you are. I meant in here that "if you want to rebuild all images from files.pharo.org" you can walk all commits.
Yeah, I did not mean that we have to change it. But we have to keep in mind that before files.pharo.org was used for versioning purposes but in a process where we are bootstrapping from sources, the intermediate generated images are build artifacts and are just a "cache". I know the launcher depends on it right now, but does it make sense that it provides access to every alpha image
Ok, that's easily doable :)
bitness. Images are portable between operating systems but not between 32&64 bit vms.
I like that they make the metadata more explicit. Otherwise we will start having strange scripts that have magic numbers here and there. At least like this we can read the file name and identify what is each field. I prefer to pay some extra bytes in filenames... About column names in UIs.... That's a UI problem. I'd not design the filename of our build artifacts because of a UI...
I like that. The only thing is that right now what is "alpha" version is managed in the file server as "latest". That will otherwise break zeroconf scripts that depend on that. I'd say every build in development is alpha so far. At some point we will move to beta. Releases and release candidates should be managed explicitly (like there is someone that will decide "this is a release and I'll tag it explicitly like it").
I did not get this one. Guille |
On Mon, Aug 7, 2017 at 12:25 AM, Guillermo Polito <[hidden email]> wrote:
So should PharoLauncher attach a datestamp to each entity? There needs to be something visible that a human can sort by. I guess this is an interim solution until PharoLauncher is made to work with Iceberg, but we need something working until then.
got it.
It may make sense when someone wants to bisect an Issue to determine when a defect was introduced. How does the time downloading ten images compare to bootstrapping ten images?
fair enough.
I was thinking something like below, but perhaps it gets too awkward after 7.0.0. Pharo-${IMAGE_KIND}${BITNESS}- Pharo-${IMAGE_KIND}${BITNESS}- ... Pharo-${IMAGE_KIND}${BITNESS}- Pharo-${IMAGE_KIND}${BITNESS}- Pharo-${IMAGE_KIND}${BITNESS}- Pharo-${IMAGE_KIND}${BITNESS}- cheers -ben |
On Mon, Aug 7, 2017 at 3:17 AM, Ben Coman <[hidden email]> wrote:
But PharoLauncher does not access commits. It never did. I think it gets all information from the file server and the naming schema of files...
True true. That's why I say it's a cache :). While this is cheap enough to have all builds stored, I'm ok with it.
Ah! I understand now. You want to tag with a # the latest build.
|
On Mon, Aug 7, 2017 at 7:32 PM, Guillermo Polito <[hidden email]> wrote:
Yes. Which is why we need either: * the filenames on the file server to include a build number or date * PharoLauncher modified to get the date from the directory info to mix into its displayed name which is preferable? cheers -ben |
Anything changed here?
Stephan |
Free forum by Nabble | Edit this page |