Opened 17 years ago

Closed 16 years ago

#12013 closed defect (fixed)

"port upgrade" tries to activate an installed version before building the new version

Reported by: vinc17@… Owned by: kballard (Lily Ballard)
Priority: Normal Milestone: MacPorts 1.7.0
Component: base Version: 1.4.42
Keywords: haspatch Cc: boeyms@…, jmroot (Joshua Root)
Port:

Description

I have the following problem:

prunille:~> port installed python24
The following ports are currently installed:
  python24 @2.4.3_1+darwin_8 (active)
  python24 @2.4.4_0+darwin_8
prunille:~> sudo port -v -d upgrade python24
DEBUG: Found port in file:///Users/vinc17/software/dports/lang/python24
DEBUG: Found port in file:///opt/local/var/db/dports/sources/rsync.rsync.macports.org_dpupdate_dports/lang/python24
--->  Activating python24 2.4.4_0+darwin_8
DEBUG: Image error: Another version of this port (python24 @2.4.3_1+darwin_8) is already active.
    while executing
"portimage::activate $portname $version_installed$variant $optionslist"
Error: Activating python24 2.4.4_0 failed: Image error: Another version of this port (python24 @2.4.3_1+darwin_8) is already active.
prunille:~> port info python24
Warning: Found 2 port python24 definitions, displaying first one.
python24 2.4.4, Revision 1, lang/python24 (Variants: universal, puredarwin, darwin_8)
[...]

"port upgrade" shouldn't have tried to activate version 2.4.4_0 since the goal is to build and install version 2.4.4_1.

Attachments (1)

upgrade-deactivate.diff (2.6 KB) - added by jmroot (Joshua Root) 17 years ago.
proposed fix

Download all attachments as: .zip

Change History (11)

comment:1 Changed 17 years ago by gwhitney@…

Seems as though the component should be changed to "base", it seems as though it's unlikely that there's anything specific to python24 going on here, but rather general issues with update.

comment:2 Changed 17 years ago by vinc17@…

Component: portsbase

Yes, I forgot to set Component to base...

comment:3 Changed 17 years ago by kballard (Lily Ballard)

Owner: changed from macports-dev@… to eridius@…
Status: newassigned

IIRC, port upgrade does an activate first for some historical reason which I don't remember. The odd thing is that it's trying to activate the wrong version here - perhaps it defaults to activating the newest version, and you have an older version as the currently activated port?

comment:4 Changed 17 years ago by kballard (Lily Ballard)

Cc: vinc17@… added; vinc17@… removed

comment:5 Changed 17 years ago by vinc17@…

Yes, there are problems with the newer version, so that I have the older one activated.

comment:6 Changed 17 years ago by nox@…

Cc: vinc17@… eridius@… boeyms@… added; vinc17@… removed
Milestone: MacPorts base bugs
Priority: ExpectedNormal

Changed 17 years ago by jmroot (Joshua Root)

Attachment: upgrade-deactivate.diff added

proposed fix

comment:7 Changed 17 years ago by jmroot (Joshua Root)

Cc: jmr@… added; vinc17@… eridius@… removed
Milestone: MacPorts base bugsMacPorts 1.6.1

The comment here says that upgrade will deactivate any active version of the port before activating the latest installed version. The code to do that is broken though. The test around the deactivate call is always false, and the deactivate call itself doesn't use the full version spec (which would cause it to fail if it were ever actually reached).

The purpose of testing at all instead of just deactivating whatever's active seems to be to avoid deactivating if the latest version is already the one that is active. The attached patch should hopefully make this work as intended.

I'm also proposing this for the 1.6.1 milestone.

comment:8 Changed 17 years ago by jmroot (Joshua Root)

Keywords: haspatch added

comment:9 Changed 17 years ago by jmroot (Joshua Root)

I've tested the patch and it seems to do the right thing in each of the different cases, so I committed it to trunk in r36762. Leaving this ticket open until the patch is merged into the 1.6 branch, or is retargeted to a later release.

comment:10 Changed 16 years ago by raimue (Rainer Müller)

Resolution: fixed
Status: assignedclosed

Marking fixed, targeted for 1.7.0.

Note: See TracTickets for help on using tickets.