generate-working-copy-states.py
98 lines
| 3.3 KiB
| text/x-python
|
PythonLexer
/ tests / generate-working-copy-states.py
Martin von Zweigbergk
|
r23447 | # Helper script used for generating history and working copy files and content. | ||
# The file's name corresponds to its history. The number of changesets can | ||||
# be specified on the command line. With 2 changesets, files with names like | ||||
# content1_content2_content1-untracked are generated. The first two filename | ||||
# segments describe the contents in the two changesets. The third segment | ||||
# ("content1-untracked") describes the state in the working copy, i.e. | ||||
# the file has content "content1" and is untracked (since it was previously | ||||
# tracked, it has been forgotten). | ||||
# | ||||
# This script generates the filenames and their content, but it's up to the | ||||
# caller to tell hg about the state. | ||||
# | ||||
# There are two subcommands: | ||||
# filelist <numchangesets> | ||||
# state <numchangesets> (<changeset>|wc) | ||||
# | ||||
# Typical usage: | ||||
# | ||||
# $ python $TESTDIR/generate-working-copy-states.py state 2 1 | ||||
# $ hg addremove --similarity 0 | ||||
# $ hg commit -m 'first' | ||||
# | ||||
# $ python $TESTDIR/generate-working-copy-states.py state 2 1 | ||||
# $ hg addremove --similarity 0 | ||||
# $ hg commit -m 'second' | ||||
# | ||||
# $ python $TESTDIR/generate-working-copy-states.py state 2 wc | ||||
# $ hg addremove --similarity 0 | ||||
# $ hg forget *_*_*-untracked | ||||
# $ rm *_*_missing-* | ||||
Gregory Szorc
|
r27295 | |||
import os | ||||
Martin von Zweigbergk
|
r23195 | import sys | ||
Martin von Zweigbergk
|
r23446 | # Generates pairs of (filename, contents), where 'contents' is a list | ||
# describing the file's content at each revision (or in the working copy). | ||||
# At each revision, it is either None or the file's actual content. When not | ||||
# None, it may be either new content or the same content as an earlier | ||||
# revisions, so all of (modified,clean,added,removed) can be tested. | ||||
def generatestates(maxchangesets, parentcontents): | ||||
depth = len(parentcontents) | ||||
if depth == maxchangesets + 1: | ||||
Pulkit Goyal
|
r36396 | for tracked in (b'untracked', b'tracked'): | ||
Augie Fackler
|
r43346 | filename = ( | ||
b"_".join( | ||||
[ | ||||
(content is None and b'missing' or content) | ||||
for content in parentcontents | ||||
] | ||||
) | ||||
+ b"-" | ||||
+ tracked | ||||
) | ||||
Martin von Zweigbergk
|
r23446 | yield (filename, parentcontents) | ||
else: | ||||
Augie Fackler
|
r43346 | for content in {None, b'content' + (b"%d" % (depth + 1))} | set( | ||
parentcontents | ||||
): | ||||
for combination in generatestates( | ||||
maxchangesets, parentcontents + [content] | ||||
): | ||||
Martin von Zweigbergk
|
r23446 | yield combination | ||
Martin von Zweigbergk
|
r23195 | |||
Augie Fackler
|
r43346 | |||
Martin von Zweigbergk
|
r23447 | # retrieve the command line arguments | ||
target = sys.argv[1] | ||||
maxchangesets = int(sys.argv[2]) | ||||
if target == 'state': | ||||
depth = sys.argv[3] | ||||
Martin von Zweigbergk
|
r23195 | |||
Martin von Zweigbergk
|
r23447 | # sort to make sure we have stable output | ||
combinations = sorted(generatestates(maxchangesets, [])) | ||||
Martin von Zweigbergk
|
r23195 | |||
# compute file content | ||||
content = [] | ||||
Martin von Zweigbergk
|
r23447 | for filename, states in combinations: | ||
Martin von Zweigbergk
|
r23195 | if target == 'filelist': | ||
Yuya Nishihara
|
r36804 | print(filename.decode('ascii')) | ||
Martin von Zweigbergk
|
r23447 | elif target == 'state': | ||
if depth == 'wc': | ||||
# Make sure there is content so the file gets written and can be | ||||
# tracked. It will be deleted outside of this script. | ||||
Pulkit Goyal
|
r36396 | content.append((filename, states[maxchangesets] or b'TOBEDELETED')) | ||
Martin von Zweigbergk
|
r23447 | else: | ||
content.append((filename, states[int(depth) - 1])) | ||||
Martin von Zweigbergk
|
r23195 | else: | ||
Robert Stanca
|
r28725 | print("unknown target:", target, file=sys.stderr) | ||
Martin von Zweigbergk
|
r23195 | sys.exit(1) | ||
# write actual content | ||||
for filename, data in content: | ||||
if data is not None: | ||||
Matt Harbison
|
r23494 | f = open(filename, 'wb') | ||
Pulkit Goyal
|
r36396 | f.write(data + b'\n') | ||
Martin von Zweigbergk
|
r23195 | f.close() | ||
elif os.path.exists(filename): | ||||
os.remove(filename) | ||||