[path] Add warning for using __getitem__
Change-Id: Iaa1659a54ef03890b12617fd7bb0b96198c881b3
Bug: 329113288
Reviewed-on: https://chromium-review.googlesource.com/c/infra/luci/recipes-py/+/5444881
Reviewed-by: Robbie Iannucci <iannucci@chromium.org>
Commit-Queue: Rob Mohr <mohrr@google.com>
diff --git a/README.recipes.md b/README.recipes.md
index 9ef5a48..94f7ee6 100644
--- a/README.recipes.md
+++ b/README.recipes.md
@@ -2826,6 +2826,8 @@
* cache (Path) - a path to put Node.js caches under.
### *recipe_modules* / [path](/recipe_modules/path)
+[DEPS](/recipe_modules/path/__init__.py#23): [warning](#recipe_modules-warning)
+
All functions related to manipulating paths in recipes.
@@ -2925,7 +2927,7 @@
Raises an ValueError if the preconditions are not met, otherwise returns the
Path object.
-— **def [abspath](/recipe_modules/path/api.py#797)(self, path: (config_types.Path | str)):**
+— **def [abspath](/recipe_modules/path/api.py#798)(self, path: (config_types.Path | str)):**
Equivalent to os.abspath.
@@ -2936,11 +2938,11 @@
Args:
* path - The path to check.
-— **def [basename](/recipe_modules/path/api.py#801)(self, path: (config_types.Path | str)):**
+— **def [basename](/recipe_modules/path/api.py#802)(self, path: (config_types.Path | str)):**
Equivalent to os.path.basename.
-  **@property**<br>— **def [cache\_dir](/recipe_modules/path/api.py#731)(self):**
+  **@property**<br>— **def [cache\_dir](/recipe_modules/path/api.py#732)(self):**
This directory is provided by whatever's running the recipe.
@@ -2963,7 +2965,7 @@
Note that directories created under here /may/ be evicted in between runs of
the recipe (i.e. to relieve disk pressure).
-— **def [cast\_to\_path](/recipe_modules/path/api.py#765)(self, strpath: str):**
+— **def [cast\_to\_path](/recipe_modules/path/api.py#766)(self, strpath: str):**
This returns a Path for strpath which can be used anywhere a Path is
required.
@@ -2982,14 +2984,14 @@
-  **@property**<br>— **def [cleanup\_dir](/recipe_modules/path/api.py#756)(self):**
+  **@property**<br>— **def [cleanup\_dir](/recipe_modules/path/api.py#757)(self):**
This directory is guaranteed to be cleaned up (eventually) after the
execution of this recipe.
This directory is guaranteed to be empty when the recipe starts.
-— **def [dirname](/recipe_modules/path/api.py#805)(self, path: (config_types.Path | str)):**
+— **def [dirname](/recipe_modules/path/api.py#806)(self, path: (config_types.Path | str)):**
For "foo/bar/baz", return "foo/bar".
@@ -3002,7 +3004,7 @@
Returns dirname of path
-— **def [eq](/recipe_modules/path/api.py#969)(self, path1: config_types.Path, path2: config_types.Path):**
+— **def [eq](/recipe_modules/path/api.py#970)(self, path1: config_types.Path, path2: config_types.Path):**
Check whether path1 points to the same path as path2.
@@ -3010,14 +3012,14 @@
**DEPRECATED**: Just directly compare path1 and path2 with `==`.
***
-— **def [exists](/recipe_modules/path/api.py#909)(self, path):**
+— **def [exists](/recipe_modules/path/api.py#910)(self, path):**
Equivalent to os.path.exists.
The presence or absence of paths can be mocked during the execution of the
recipe by using the mock_* methods.
-— **def [expanduser](/recipe_modules/path/api.py#900)(self, path):**
+— **def [expanduser](/recipe_modules/path/api.py#901)(self, path):**
Do not use this, use `api.path.home_dir` instead.
@@ -3038,7 +3040,7 @@
pass the Paths around instead of using this global variable).
***
-  **@property**<br>— **def [home\_dir](/recipe_modules/path/api.py#713)(self):**
+  **@property**<br>— **def [home\_dir](/recipe_modules/path/api.py#714)(self):**
This is the path to the current $HOME directory.
@@ -3050,7 +3052,7 @@
This is called by the recipe engine immediately after __init__(), but
with `self._paths_client` initialized.
-— **def [is\_parent\_of](/recipe_modules/path/api.py#976)(self, parent: config_types.Path, child: config_types.Path):**
+— **def [is\_parent\_of](/recipe_modules/path/api.py#977)(self, parent: config_types.Path, child: config_types.Path):**
Check whether child is contained within parent.
@@ -3058,21 +3060,21 @@
**DEPRECATED**: Just use `parent.is_parent_of(child)`.
***
-— **def [isdir](/recipe_modules/path/api.py#917)(self, path):**
+— **def [isdir](/recipe_modules/path/api.py#918)(self, path):**
Equivalent to os.path.isdir.
The presence or absence of paths can be mocked during the execution of the
recipe by using the mock_* methods.
-— **def [isfile](/recipe_modules/path/api.py#925)(self, path):**
+— **def [isfile](/recipe_modules/path/api.py#926)(self, path):**
Equivalent to os.path.isfile.
The presence or absence of paths can be mocked during the execution of the
recipe by using the mock_* methods.
-— **def [join](/recipe_modules/path/api.py#824)(self, path, \*paths):**
+— **def [join](/recipe_modules/path/api.py#825)(self, path, \*paths):**
Equivalent to os.path.join.
@@ -3110,23 +3112,23 @@
either a resource script of your recipe module or recipe.
***
-— **def [mock\_add\_directory](/recipe_modules/path/api.py#944)(self, path: config_types.Path):**
+— **def [mock\_add\_directory](/recipe_modules/path/api.py#945)(self, path: config_types.Path):**
For testing purposes, mark that file |path| exists.
-— **def [mock\_add\_file](/recipe_modules/path/api.py#940)(self, path: config_types.Path):**
+— **def [mock\_add\_file](/recipe_modules/path/api.py#941)(self, path: config_types.Path):**
For testing purposes, mark that file |path| exists.
-— **def [mock\_add\_paths](/recipe_modules/path/api.py#933)(self, path: config_types.Path, kind: FileType=FileType.FILE):**
+— **def [mock\_add\_paths](/recipe_modules/path/api.py#934)(self, path: config_types.Path, kind: FileType=FileType.FILE):**
For testing purposes, mark that |path| exists.
-— **def [mock\_copy\_paths](/recipe_modules/path/api.py#948)(self, source: config_types.Path, dest: config_types.Path):**
+— **def [mock\_copy\_paths](/recipe_modules/path/api.py#949)(self, source: config_types.Path, dest: config_types.Path):**
For testing purposes, copy |source| to |dest|.
-— **def [mock\_remove\_paths](/recipe_modules/path/api.py#955)(self, path: config_types.Path, should_remove: Callable[([str], bool)]=(lambda p: True)):**
+— **def [mock\_remove\_paths](/recipe_modules/path/api.py#956)(self, path: config_types.Path, should_remove: Callable[([str], bool)]=(lambda p: True)):**
For testing purposes, mark that |path| doesn't exist.
@@ -3135,34 +3137,34 @@
should_remove: Called for every candidate path. Return True to remove this
path.
-— **def [normpath](/recipe_modules/path/api.py#896)(self, path):**
+— **def [normpath](/recipe_modules/path/api.py#897)(self, path):**
Equivalent to os.path.normpath.
-  **@property**<br>— **def [pardir](/recipe_modules/path/api.py#782)(self):**
+  **@property**<br>— **def [pardir](/recipe_modules/path/api.py#783)(self):**
Equivalent to os.pardir.
-  **@property**<br>— **def [pathsep](/recipe_modules/path/api.py#792)(self):**
+  **@property**<br>— **def [pathsep](/recipe_modules/path/api.py#793)(self):**
Equivalent to os.pathsep.
-— **def [realpath](/recipe_modules/path/api.py#884)(self, path: (config_types.Path | str)):**
+— **def [realpath](/recipe_modules/path/api.py#885)(self, path: (config_types.Path | str)):**
Equivalent to os.path.realpath.
-— **def [relpath](/recipe_modules/path/api.py#888)(self, path, start):**
+— **def [relpath](/recipe_modules/path/api.py#889)(self, path, start):**
Roughly equivalent to os.path.relpath.
Unlike os.path.relpath, `start` is _required_. If you want the 'current
directory', use the `recipe_engine/context` module's `cwd` property.
-  **@property**<br>— **def [sep](/recipe_modules/path/api.py#787)(self):**
+  **@property**<br>— **def [sep](/recipe_modules/path/api.py#788)(self):**
Equivalent to os.sep.
-— **def [split](/recipe_modules/path/api.py#839)(self, path):**
+— **def [split](/recipe_modules/path/api.py#840)(self, path):**
For "foo/bar/baz", return ("foo/bar", "baz").
@@ -3176,7 +3178,7 @@
Returns (dirname(path), basename(path)).
-— **def [splitext](/recipe_modules/path/api.py#860)(self, path: (config_types.Path | str)):**
+— **def [splitext](/recipe_modules/path/api.py#861)(self, path: (config_types.Path | str)):**
For "foo/bar.baz", return ("foo/bar", ".baz").
@@ -3191,7 +3193,7 @@
Returns:
(name, extension_including_dot).
-  **@property**<br>— **def [start\_dir](/recipe_modules/path/api.py#702)(self):**
+  **@property**<br>— **def [start\_dir](/recipe_modules/path/api.py#703)(self):**
This is the directory that the recipe started in. it's similar to `cwd`,
except that it's constant for the duration of the entire program.
@@ -3200,7 +3202,7 @@
See the 'recipe_engine/context' module which allows modifying the cwd safely
via a context manager.
-  **@property**<br>— **def [tmp\_base\_dir](/recipe_modules/path/api.py#722)(self):**
+  **@property**<br>— **def [tmp\_base\_dir](/recipe_modules/path/api.py#723)(self):**
This directory is the system-configured temp dir.
diff --git a/recipe.warnings b/recipe.warnings
index aae0b34..a544118 100644
--- a/recipe.warnings
+++ b/recipe.warnings
@@ -85,6 +85,15 @@
}
warning {
+ name: "PATH_GETITEM_DEPRECATED"
+ description: "Accessors like api.path['start_dir'] are deprecated."
+ description: ""
+ description: "Use a member like api.path.start_dir instead"
+ deadline: "2024-05-15"
+ google_issue { id: 329113288 }
+}
+
+warning {
name: "SET_BUILDBUCKET_HOST_DEPRECATED"
description: "api.buildbucket.set_buildbucket_host() is deprecated."
description: ""
diff --git a/recipe_modules/path/__init__.py b/recipe_modules/path/__init__.py
index 716a573..7852234 100644
--- a/recipe_modules/path/__init__.py
+++ b/recipe_modules/path/__init__.py
@@ -19,3 +19,7 @@
), default={},
)
}
+
+DEPS = [
+ 'recipe_engine/warning',
+]
diff --git a/recipe_modules/path/api.py b/recipe_modules/path/api.py
index a1943fc..3f36307 100644
--- a/recipe_modules/path/api.py
+++ b/recipe_modules/path/api.py
@@ -697,6 +697,7 @@
* checkout_dir (but use of checkout_dir is generally discouraged - just
pass the Paths around instead of using this global variable).
"""
+ self.m.warning.issue('PATH_GETITEM_DEPRECATED')
return self.get(name)
@property