Edgewall Software
Modify

Opened 16 years ago

Closed 16 years ago

#8388 closed enhancement (fixed)

More flexibility in subclassing functional test infrastructure

Reported by: osimons Owned by: osimons
Priority: normal Milestone: 0.11.5
Component: general Version: 0.11-stable
Severity: normal Keywords:
Cc: felix.schwarz@… Branch:
Release Notes:
API Changes:
Internal Changes:

Description

I'd like to reuse the functional test infrastructure for plugin tests. However, all commands are 'hardwired' to presume they are run as Trac tests with '.' as common base source directory.

With plugin tests, I'd need just Trac source being on path to make test infrastructure importable and callable, but will create my own test environment inside plugin source.

To handle common base + allow for running any internal 'tweaks', I've made a patch that I think is a nice clean solution for this:

  • It adds a self.trac_src variable that just defaults to '.'
  • All command calls are updated to do os.join() on the common base
  • Added a init() hook that a subclass can implement to adjust any internal settings before any methods are called

I haven't been much involved in testing so far, so I'd like input from others before taking any actions - even though subclassing the infrastructure have been quite insightful…

Patch follows. All regular Trac tests pass fine, and I'm able to create a plugin test infrastructure in 25 lines of code. Nice :-)

Attachments (1)

t8388-testenv_subclass-r8265-011.diff (3.0 KB ) - added by osimons 16 years ago.
Easier reuse of functional test infrastructure.

Download all attachments as: .zip

Change History (10)

by osimons, 16 years ago

Easier reuse of functional test infrastructure.

comment:1 by osimons, 16 years ago

Owner: set to osimons

comment:2 by Felix Schwarz <felix.schwarz@…>, 16 years ago

Cc: felix.schwarz@… added

comment:3 by Eli Carter, 16 years ago

Looks good. I'd like to get Tim to give it the once-over in case I'm missing something.

comment:4 by Christian Boos, 16 years ago

Looks good to me as well. You can already commit it on the rework-testing branch, if it needs more work, we can do it there before propagating the change to 0.11-stable and trunk.

comment:5 by osimons, 16 years ago

Oki. Committed to branch in [8268].

comment:6 by osimons, 16 years ago

BTW, I've committed the test infrastructure for the trachacks:wiki:XmlRpcPlugin that uses/depends on this patch: trachacks:changeset:6064 (see tests/__init__.py for how it is used).

comment:7 by osimons, 16 years ago

Milestone: 0.11.60.11.5

This one should be ready to include in 0.11.5.

What is the merge-strategy for rework-testing back to 0.11-stable? Apply patch to 0.11-stable, merge to trunk, and then a --record-only merge in rework-testing to block it as it is already applied? Confused :-)

in reply to:  7 comment:8 by Christian Boos, 16 years ago

Replying to osimons:

This one should be ready to include in 0.11.5.

What is the merge-strategy for rework-testing back to 0.11-stable? Apply patch to 0.11-stable, merge to trunk, and then a --record-only merge in rework-testing to block it as it is already applied?

Yes, except for the last step: we haven't reintegrated yet any change from trunk on the rework-testing branch, and I think there's no point in doing so now. If new changes from trunk really need to be taken into account for further developments on the rework-testing topic, then we should rather recreate the branch, in order to avoid a huge merge changeset.

Confused :-)

Normal, we're doing crazy stuff in order to stress-test #7715 ;-)

comment:9 by osimons, 16 years ago

Resolution: fixed
Status: newclosed

Committed in [8305:8306].

Modify Ticket

Change Properties
Set your email in Preferences
Action
as closed The owner will remain osimons.
The resolution will be deleted. Next status will be 'reopened'.
to The owner will be changed from osimons to the specified user.

Add Comment


E-mail address and name can be saved in the Preferences .
 
Note: See TracTickets for help on using tickets.