sapling/tests/test-copytrace-manual-t.py
Jun Wu 5e5465c313 testutil/dott: match shell's behavior on quote handling
Summary:
This diff makes the code closer to shell behavior.

For example, globs are disabled for both single and double quotes:

  ~ % echo /bin/bash*
  /bin/bash /bin/bashbug
  ~ % echo "/bin/bash*"
  /bin/bash*
  ~ % echo '/bin/bash*'
  /bin/bash*

Environment variables are not expanded for single qutoes:

  ~ % echo $PWD
  /home/quark
  ~ % echo "$PWD"
  /home/quark
  ~ % echo '$PWD'
  $PWD

Tests using single quoted environment varialbes are updated to use double
quotes, mostly by using this vim command:

  %s/\(sh % ".*\)'\([^'$]*\$[^']*\)'/\1\\"\2\\"

The translation script was updated to prefer double quotes to preserve
environment variable expansion behavior.

Reviewed By: xavierd

Differential Revision: D17675351

fbshipit-source-id: d5c8d5f23ea8e29fe093c4e6ae89ddacda97141e
2019-09-30 16:53:25 -07:00

65 lines
1.5 KiB
Python

# Copyright (c) Facebook, Inc. and its affiliates.
#
# This software may be used and distributed according to the terms of the
# GNU General Public License version 2 or any later version.
from __future__ import absolute_import
from testutil.dott import feature, sh, testtmp # noqa: F401
sh % "enable rebase"
sh % "newrepo"
sh % "drawdag" << r"""
D # A/A=1\n
| # B/A=(removed)
B C # B/Renamed=1\n
|/ # C/A=2\n
A
"""
sh % "hg up -q $C"
sh % "hg rebase -r $C -d $D '--config=ui.interactive=1' '--config=experimental.copytrace=off'" << r"""
r
Renamed
""" == r"""
rebasing 2:85b47c0eb942 "C"
other [source] changed A which local [dest] deleted
use (c)hanged version, leave (d)eleted, leave (u)nresolved, or input (r)enamed path? r
path 'A' in commit 85b47c0eb942 was renamed to [what path] in commit ed4ad4ec6472 ? Renamed
merging Renamed"""
sh % "hg log -Gp -T '{desc}\\n' --git Renamed A" == r"""
@ C
: diff --git a/Renamed b/Renamed
: --- a/Renamed
: +++ b/Renamed
: @@ -1,1 +1,1 @@
: -1
: +2
:
o B
| diff --git a/A b/A
| deleted file mode 100644
| --- a/A
| +++ /dev/null
| @@ -1,1 +0,0 @@
| -1
| diff --git a/Renamed b/Renamed
| new file mode 100644
| --- /dev/null
| +++ b/Renamed
| @@ -0,0 +1,1 @@
| +1
|
o A
diff --git a/A b/A
new file mode 100644
--- /dev/null
+++ b/A
@@ -0,0 +1,1 @@
+1"""
# status should not show "! A"
sh % "hg status" == ""