Merge lp:~jmarsden/ubiquity/lp775124 into lp:ubiquity

Proposed by Jonathan Marsden
Status: Work in progress
Proposed branch: lp:~jmarsden/ubiquity/lp775124
Merge into: lp:ubiquity
Diff against target: 34 lines (+12/-1)
2 files modified
debian/changelog (+6/-1)
ubiquity/plugins/ubi-prepare.py (+6/-0)
To merge this branch: bzr merge lp:~jmarsden/ubiquity/lp775124
Reviewer Review Type Date Requested Status
Dimitri John Ledkov Needs Resubmitting
Evan (community) Needs Fixing
Review via email: mp+73963@code.launchpad.net

Description of the change

Checks for Lubuntu or Xubuntu seeds, and if found, uses a more appropriate minimum free space determination of casper/filesystem.size + 600MB.

This allows these flavours to install on low disk space machines, including those with 4GB SSDs.

See LP bug #775124.

To test, install Lubuntu from LiveCD into a 4GB Virtualbox machine -- you cannot do so on current Lubuntu 11.04 or 11.10 Beta 1 LiveCD images because of this issue.

To post a comment you must log in.
Revision history for this message
Colin Watson (cjwatson) wrote :

This really ought to be done by having the Xubuntu and Lubuntu images
preseed a specific debconf template, rather than by checking for the
existence of preseed files at run-time.

Revision history for this message
Jonathan Marsden (jmarsden) wrote :

I thought there should be a better way, but I didn't get as far as figuring out what it was! Also, I was looking for a small quick fix, something that might be simple enough to validate that it could get accepted even though we are already in beta :) Sounds like you would prefer I "do it right"... OK.

I think you are saying that there should be a debconf variable ubiquity/minfreespace (or some such name), defined in the debian/templates file in the ubiquity package, and if that variable exists, then ubi-prepare.py would use that value as the offset to filesystem.size to compute the minimum disk space needed, rather than my 600MB hardcoded constant. Otherwise, default to filesystem.size*2 as now, strange though that *2 is.

That makes sense, but I'm not sure I know quite how to do that in Python, and I was looking for a small quick fix that might be simple enough to validate that it could get accepted during beta :)

I'll see what I can come up with using debconf. Oh... once I code this, how can I test it? Is there a way to edit a local copy of lubuntu.seed to include a line setting this new debconf variable, and then say "build me an ISO" using this seed, on my local machine? I understand the build process enough to know what a seed file does and how to edit it to set a debconf variable with a d-i line, but not enough to know how to cause an ISO build to happen locally using a local repository mirror. Pointers appreciated.

Thanks,

Jonathan

Revision history for this message
Stéphane Graber (stgraber) wrote :

Hi, I just noticed this merge proposal in my e-mails :)

Last week I update ubi-prepare a bit so that it now has an hardcoded maximum disk space variable, currently set to 8GB.

That's, if filesystem.size*2 is higher than 8GB and filesystem.size*2 + 20% still fit in 8GB, the installer is only going to ask for 8GB (instead of around 14GB in the case of Edubuntu).

I guess that doesn't help much flavours using CDs, but if we want to make something preseedable, I'd suggest that variable be the right candidate.

Revision history for this message
Jonathan Marsden (jmarsden) wrote :

Stéphane: I thought that was new when I saw it, but I didn't check the bzr history of it.

To me, that code looks like a workaround for another side-effect of the *2 problem. Basically *2 is not really the correct "fudge factor" for many Ubuntu flavours, IMO.

If we make the preseeded variable the total disk space to ask for, as you suggest, then every time the size of a default install changes, we might need to edit the seed file. If instead we make the preseeded variable the offset from the filesystem.size, that is, the minimum amount of free space needed in addition to the file size being installed, then the total size requirement will 'automatically' change as the size of the stuff in the default install changes, and the seed file only needs a manual update when the amount of free space needed by the installer changes.

My guess is that the size of the default install could change a lot more often than the amount of extra space needed by the installer to work in. On that basis, it seems more useful to me to preseed the offset, the "extra space" needed, rather than the total space requirement.

Based on Colin's suggestion, I have played with using debconf info from Python in test programs, and they work fine if the program is called as debconf ./mytestprogram.py -- but I don't yet know how to access the debconf database correctly/safely from inside a ubiquity plugin. Will the debconf database have already been opened somewhere when the plugin code is called, so there is an existing (global?) db object the plugin can use to do something like

  db.get('ubiquity/minfreediskspace')

with? Or do I need to do the

  import debconf
  db = debconf.Debconf()

inside ubi-prepare.py itself?

Is there documentation somewhere detailing the environment that ubiquity plugins such as ubi-prepare.py run in, and what things ubiquity has already done "above" them which they can make use of? Or do I just have to read all the code :)

Thanks,

Jonathan

Revision history for this message
Evan (ev) wrote :

Jonathan,

We try to split the code that touches debconf from the UI code as much as possible. In the case of plugins such as ubi-prepare, code that reads from debconf should be located in the Page class, under the prepare function in your case. That should then call self.ui.some_function_to_set_the_ui_appropriately, making sure to either implement it in an interface-neutral way, or account for the KDE frontend either by implementing a function in PageKde as well as PageGtk, or by stubbing out a default function in PageBase or PageKde.

Hope that helps!

Revision history for this message
Evan (ev) wrote :

I don't know why I didn't make this comment earlier, but I do not believe we should be special casing Ubuntu flavors here at all.

For what it's worth, the fudge factor is there not as a workaround, but because we do not want users creating an Ubuntu installation that is only just big enough to contain the system files. We should ensure they have enough room to be able to use the operating system, including storing documents, music, and downloads, for the life of the installation.

review: Needs Fixing
Revision history for this message
Dimitri John Ledkov (xnox) wrote :

Ideally the iso image would self declare the desired minimal install sizes (e.g. similar to the .disk/info file) and then it would be used in the installer, else use the default fudge factor.

review: Needs Fixing
Revision history for this message
Dimitri John Ledkov (xnox) wrote :

The development of ubiquity has moved to git, still hosted on launchpad. If this merge proposal is still relevant, please resubmit it against the git branches found at https://code.launchpad.net/ubiquity

Sorry for any inconvenience caused.

review: Needs Resubmitting

Unmerged revisions

4926. By Jonathan Marsden

ubiquity/plugins/ubi-prepare.py: Allow low-resource-oriented
Ubuntu flavours to install in appropriate low disk space
environments. (LP: #775124)

Preview Diff

[H/L] Next/Prev Comment, [J/K] Next/Prev File, [N/P] Next/Prev Hunk
1=== modified file 'debian/changelog'
2--- debian/changelog 2011-09-02 11:59:28 +0000
3+++ debian/changelog 2011-09-03 20:37:24 +0000
4@@ -11,7 +11,12 @@
5 work with either the old (2.28) nor the current (2.90) pygobject, and
6 still uses gconf. (LP: #829186)
7
8- -- Evan Dandrea <ev@ubuntu.com> Thu, 01 Sep 2011 14:53:45 +0100
9+ [ Jonathan Marsden ]
10+ * ubiquity/plugins/ubi-prepare.py: Allow low-resource-oriented
11+ Ubuntu flavours to install in appropriate low disk space
12+ environments. (LP: #775124)
13+
14+ -- Jonathan Marsden <jmarsden@fastmail.fm> Sat, 03 Sep 2011 13:20:14 -0700
15
16 ubiquity (2.7.26) oneiric; urgency=low
17
18
19=== modified file 'ubiquity/plugins/ubi-prepare.py'
20--- ubiquity/plugins/ubi-prepare.py 2011-08-30 15:07:13 +0000
21+++ ubiquity/plugins/ubi-prepare.py 2011-09-03 20:37:24 +0000
22@@ -332,6 +332,12 @@
23 # TODO substitute into the template for the state box.
24 min_disk_size = size * 2 # fudge factor.
25
26+ # Revert Evan Dandrea 'fudge factor' for low resource flavours
27+ if os.path.exists('/cdrom/preseed/lubuntu.seed'):
28+ min_disk_size = size + (600 * 1024 * 1024) # 600MB
29+ if os.path.exists('/cdrom/preseed/xubuntu.seed'):
30+ min_disk_size = size + (600 * 1024 * 1024) # 600MB
31+
32 # Set minimum size to 8GB if current minimum size is larger
33 # than 8GB and we still have an extra 20% of free space
34 if min_disk_size > max_size and size * 1.2 < max_size:

Subscribers

People subscribed via source and target branches

to status/vote changes: