Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

proposal for deploy() feature #15172

Merged
merged 5 commits into from
Nov 29, 2023
Merged

Conversation

memsharded
Copy link
Member

@memsharded memsharded commented Nov 24, 2023

Changelog: Feature: New deploy() method in recipes for explicit per-recipe deployment.
Docs: conan-io/docs#3494

Close #14811

@czoido
Copy link
Contributor

czoido commented Nov 27, 2023

The only thing I'm not sure about is the naming of the argument. Perhaps something like --deploy-requires=... would be more aligned with the naming of other arguments?

@AbrilRBS
Copy link
Member

Perhaps something like --deploy-requires=...

I don't agree with this one, I think requires would give the wrong impression here? Not sure though, happy to look-into it tomorrow :)

@memsharded
Copy link
Member Author

The only thing I'm not sure about is the naming of the argument. Perhaps something like --deploy-requires=... would be more aligned with the naming of other arguments?

There might be an issue, this introduces some ambiguity with tool-requires, will there be a --deploy-tool-requires too?

@czoido
Copy link
Contributor

czoido commented Nov 28, 2023

The only thing I'm not sure about is the naming of the argument. Perhaps something like --deploy-requires=... would be more aligned with the naming of other arguments?

There might be an issue, this introduces some ambiguity with tool-requires, will there be a --deploy-tool-requires too?

Then maybe --deploy-package/s instead --deployer-pkg ?

@franramirez688 franramirez688 self-requested a review November 28, 2023 14:07
@memsharded memsharded marked this pull request as ready for review November 28, 2023 16:14
@czoido czoido merged commit 29e9f95 into conan-io:release/2.0 Nov 29, 2023
2 checks passed
@memsharded memsharded deleted the feature/deploy branch November 29, 2023 10:09
conan/cli/commands/install.py Show resolved Hide resolved
assert "Executing deploy()" not in c.out

# install can deploy all
c.run("install --requires=pkg/0.1 --deployer-package=* --deployer-folder=mydeploy")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yep, I think that this is a great interface. You're right, we might want to deploy multiple packages at once. I'm wondering about overloading the --deployer-folder though - is the design intention here that each deployer is responsible for namespacing itself within the deployer-folder? For instance, if I run

$ conan install --requires=foo/0.1.0 --deployer-package=foo/0.1.0 --deployer=licenses --deployer=full_deploy --deployer-folder=/tmp/deploy-test

then each of the deployers (kind of) conflict:

$tree /tmp/deploy-test -L 2
/tmp/deploy-test
├── conaninfo.txt
├── conanmanifest.txt
├── full_deploy
│   └── host
├── include
│   └── foo.h
├── lib
│   └── libfoo.a
└── licenses.zip

full_deploy namespaces itself properly, licenses.py (from the conan-extensions repo) places licenses.zip in the root of the deployer folder, and in this case I've emulated your deploy() method, which copies the package folder to the root. If this is the most desirable design, then a best practice would need to emerge to avoid contaminating other deployments (i.e., by outputing to a subfolder of deploy-folder). Or is there another design that might remove the need for a best practice?

I guess removing the need for a best practice also has issues - this is the most flexible, and gives the user the most room to construct things the way they want, at the cost of a (potential) maintenance overhead in ensuring deployers deploy consistently if there's a possibility of a clash.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, I think it should be the responsibility of the users to namespace their deploys if that is what they want/need. If we try to namespace something, then it would be certainly blocking for users that want to deploy all .dlls in a single common folder to all dependencies for example, and they want to do it in their deploy() method.

Once deployers are running from different origins and different packages deploy() now, the space for conflict is always there (they could be deploying directly to /usr/bin etc, and conflicting anyway). The full_deploy implement the namespace in itself, it is not something external, with the intention that users can take it as inspiration and easily customize the namespace/layout of the deployment to fit their needs.

The rule of thumb is that deployers copy to user space, and as such it is the full responsibiliy of the user (via the different deployers implementations) to control that user space. And then, yes, some common practices might happen with some common namespaces patterns, but that should be it, just some common practices, not something mandated or implemented by the tool.

@memsharded memsharded mentioned this pull request Dec 1, 2023
1 task
AbrilRBS added a commit to AbrilRBS/conan that referenced this pull request Dec 18, 2023
commit 98d8f6a
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Sun Dec 17 20:37:54 2023 +0100

    Try to address NMakeDeps quoting issues (conan-io#15140)

    * Better spacing and quotes for defines in NMakeDeps

    * No need to escape parenthesis in defines

    * Fix tests

    * Follow proper syntax definition

    * Add numeric test

    * Ensure functional tests cover the quoting

    * Add test for space in values

    * fix values with whitespace in nmaketoolchain defines

    * fix nmakedeps and test

    * simplify

    * review

    ---------

    Co-authored-by: danimtb <danimanzaneque@gmail.com>

commit 94a3549
Author: memsharded <james@conan.io>
Date:   Sat Dec 16 23:45:06 2023 +0100

    fix broken test after source() VirtualBuildEnv

commit 6958893
Author: James <james@conan.io>
Date:   Fri Dec 15 14:00:05 2023 +0100

    Define toolset and architecture in CMakePresets.json for VS to avoid mismatches (conan-io#15215)

    * checking what breaks

    * fix test

    * testing it really fix something

    * wip

    * wip

commit 7921be1
Author: James <james@conan.io>
Date:   Fri Dec 15 12:45:07 2023 +0100

    adding tools.microsoft:winsdk_version conf (conan-io#15272)

    * adding tools.microsoft:winsdk_version conf

    * fix tests

    * wip

    * fix

    * review

commit 018441d
Author: James <james@conan.io>
Date:   Fri Dec 15 12:38:10 2023 +0100

    new CMake.ctest() method (conan-io#15282)

commit 053f22a
Author: James <james@conan.io>
Date:   Fri Dec 15 12:23:57 2023 +0100

    Feature/cmakedeps legacy adapter (conan-io#15207)

    * reusing fixture, will reduce CI time

    * proposal for legacy cmake-like generator

    * better ux for VS not found error (conan-io#15250)

    * better ux

    * improve

    * Update conan/tools/microsoft/visual.py

    Co-authored-by: Rubén Rincón Blanco <git@rinconblanco.es>

    ---------

    Co-authored-by: Rubén Rincón Blanco <git@rinconblanco.es>

    * fix and remove more xfails (conan-io#15251)

    fix and remove xfails

    * Fix/save restore portable (conan-io#15253)

    * make save-restore portable

    * msg

    * require-replaces proposal (conan-io#15136)

    * wip

    * test passing

    * wip

    * wip

    * wip

    * wip

    * wip

    * wip

    * new approach

    * extra checks

    * more tests

    * review

    * Fix failing tests in macos (conan-io#15255)

    Fix tests in macos

    * Add test to ensure &: syntax works in `--requires` install (conan-io#15258)

    Add test to ensure &: syntax qorks in --requires install

    * add CONAN_LOG_LEVEL env-var (conan-io#15263)

    * add CONAN_LOG_LEVEL env-var

    * Update conan/cli/command.py

    ---------

    Co-authored-by: Francisco Ramírez <franchuti688@gmail.com>

    * review

    * review

    ---------

    Co-authored-by: Rubén Rincón Blanco <git@rinconblanco.es>
    Co-authored-by: Rubén Rincón Blanco <rubenrb@jfrog.com>
    Co-authored-by: Francisco Ramírez <franchuti688@gmail.com>

commit 9afacb4
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Fri Dec 15 11:32:21 2023 +0100

    Add different ref tracking syntax for  `<host_version>` (conan-io#15274)

    * Use light=True where possible in build_requires tests

    * Sketch for allowing tracking of different ref

    * Add remote input to build-map command

    * Update conans/client/graph/graph_builder.py

    Co-authored-by: James <memsharded@gmail.com>

    * Update conans/client/graph/graph_builder.py

    Co-authored-by: James <memsharded@gmail.com>

    * Update conans/client/graph/graph_builder.py

    Co-authored-by: James <memsharded@gmail.com>

    * Fix tests

    ---------

    Co-authored-by: James <memsharded@gmail.com>

commit 92af096
Author: Luis Caro Campos <3535649+jcar87@users.noreply.github.com>
Date:   Fri Dec 15 10:10:45 2023 +0000

    Add pyproject.toml (conan-io#15186)

    * Move to pyproject.toml

    * Exclude conan server

    * Try adding a line

    * Upgrade pip in venv

    * update setuptools too

    * Read version from conans.__init__

    * Restore setup.py for compatibility

    * Minimal pyproject toml

    * Restore setup.py

    * Restore jenkinsfile

commit 0c786c5
Author: Carlos Zoido <mrgalleta@gmail.com>
Date:   Fri Dec 15 01:36:22 2023 +0100

    Add environment information to CMakePresets (conan-io#15192)

    * build to config and run to test preset

    * first draft

    * revert

    * wip

    * fix format

    * test ctest

    * simplify

    * get env in right place

    * move test

    * fix windows

    * hopefully fix tests

    * fix test

    * fix test again

    * simplify test

    * add opt-out

    * wip

    * auto_generate for run env

    * minor changes

commit 5becb2a
Author: Juan <35701596+juansblanco@users.noreply.github.com>
Date:   Thu Dec 14 15:58:32 2023 +0100

    Make paths format in layout consistent on Windows (conan-io#15260)

    Changelog: Omit
    Docs: Omit

commit 9f023c3
Author: James <james@conan.io>
Date:   Thu Dec 14 15:48:28 2023 +0100

    proposal for source() buildenv discussion (conan-io#15153)

    * proposal for source() buildenv discussion

    * wip, failing

    * trying alternative opt-in class attribute

    * fix

    * wip

    * wip

    * add cmake_layout test

    * wip

    * named auto_generate

commit 0843372
Author: James <james@conan.io>
Date:   Thu Dec 14 12:34:54 2023 +0100

    fix migration lru (conan-io#15135)

    * fix migration lru

    * fix back migration

commit c655809
Author: Carlos Zoido <mrgalleta@gmail.com>
Date:   Wed Dec 13 16:32:02 2023 +0100

    Add pkglist formatter for conan export command (conan-io#15266)

    add pkglist formatter and test

commit d0e6a3f
Author: James <james@conan.io>
Date:   Wed Dec 13 13:59:50 2023 +0100

    optimize test (conan-io#15214)

    * optimize test

    * fixes

    * fix

commit 6f3f445
Author: James <james@conan.io>
Date:   Wed Dec 13 12:57:00 2023 +0100

    add CONAN_LOG_LEVEL env-var (conan-io#15263)

    * add CONAN_LOG_LEVEL env-var

    * Update conan/cli/command.py

    ---------

    Co-authored-by: Francisco Ramírez <franchuti688@gmail.com>

commit 032eefc
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Tue Dec 12 19:43:09 2023 +0100

    Add test to ensure &: syntax works in `--requires` install (conan-io#15258)

    Add test to ensure &: syntax qorks in --requires install

commit 694b7d1
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Tue Dec 12 14:57:14 2023 +0100

    Fix failing tests in macos (conan-io#15255)

    Fix tests in macos

commit 286d552
Author: James <james@conan.io>
Date:   Tue Dec 12 14:16:18 2023 +0100

    require-replaces proposal (conan-io#15136)

    * wip

    * test passing

    * wip

    * wip

    * wip

    * wip

    * wip

    * wip

    * new approach

    * extra checks

    * more tests

    * review

commit 7aa0b4b
Author: James <james@conan.io>
Date:   Tue Dec 12 12:21:02 2023 +0100

    Fix/save restore portable (conan-io#15253)

    * make save-restore portable

    * msg

commit 1c43d5f
Author: James <james@conan.io>
Date:   Tue Dec 12 09:43:07 2023 +0100

    fix and remove more xfails (conan-io#15251)

    fix and remove xfails

commit 2717bbe
Author: James <james@conan.io>
Date:   Mon Dec 11 20:06:14 2023 +0100

    better ux for VS not found error (conan-io#15250)

    * better ux

    * improve

    * Update conan/tools/microsoft/visual.py

    Co-authored-by: Rubén Rincón Blanco <git@rinconblanco.es>

    ---------

    Co-authored-by: Rubén Rincón Blanco <git@rinconblanco.es>

commit 5ef6824
Author: James <james@conan.io>
Date:   Mon Dec 11 15:18:06 2023 +0100

    drop --build unused patterns unused functionality (conan-io#15233)

commit 1d058e9
Author: James <james@conan.io>
Date:   Mon Dec 11 13:47:21 2023 +0100

    fix deploy absolute folders (conan-io#15244)

    * fix deploy absolute folders

    * fix tests

commit 63ee9c7
Author: James <james@conan.io>
Date:   Mon Dec 11 07:59:37 2023 +0100

    allow hard set_name() set_version() (conan-io#15211)

commit 37573ee
Author: James <james@conan.io>
Date:   Thu Dec 7 15:09:24 2023 +0100

    Tests maintenance, fix some xfail, remove other xfails (conan-io#15234)

    remove xfail

commit e6aa291
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Thu Dec 7 15:04:23 2023 +0100

    Add `in` operator support for ConanFile's `self.dependencies` (conan-io#15221)

    * Add in operator support for ConanFile self.dependencies

    * Ensure tool_requires also work

commit a6f42bf
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Wed Dec 6 12:57:44 2023 +0100

    Fix range escaping in conflict reports involving ranges (conan-io#15222)

    * Add failing test that should pass after issue is fixed

    * Fix range escaping in conflict reports involving ranges

commit acbaf44
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Mon Dec 4 23:16:38 2023 +0100

    Fix `conan graph explain` binary distance calculation (conan-io#15212)

    * Bugfix binary distance calculation

    * Add proper distance culling test

commit 5493a77
Author: James <james@conan.io>
Date:   Mon Dec 4 08:27:53 2023 +0100

    reusing fixture, will reduce CI time (conan-io#15204)

commit 412a027
Author: James <james@conan.io>
Date:   Fri Dec 1 13:58:04 2023 +0100

    New [platform_requires]  similar to system-tools, but for all requires (conan-io#14871)

    * wip

    * test passing

    * wip

    * wip

    * wip

    * wip

    * wip

    * renaming and review

    * fixes

    * add missing dumps

    * Simplified if-else clauses. Keeping more prio for platform_tool_requires

    * Renamed first naming proposal

    * review test, new check

    * fix test

    * fix

    ---------

    Co-authored-by: Francisco Ramirez de Anton <franchuti688@gmail.com>

commit 1f548d8
Author: Luis Caro Campos <3535649+jcar87@users.noreply.github.com>
Date:   Fri Dec 1 09:57:43 2023 +0000

    Fix pyinstaller script on Windows (conan-io#15194)

commit dc98b6a
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Fri Dec 1 10:25:16 2023 +0100

    Fix `conan graph info --format=html` reporting misleading conflicting nodes (conan-io#15196)

    * Fix graph info --format=html conflict report misleading nodes

    * Add node map test

commit 3f3fd45
Author: memsharded <james@conan.io>
Date:   Thu Nov 30 00:33:54 2023 +0100

    wip

commit 9145028
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Wed Nov 29 22:47:57 2023 +0100

    Add `redirect_stdout` to CMake integration methods (conan-io#15150)

    * Add redirect_stdout to CMake integration methods

    * Fix windows tests

    * Simplify tests

    * Directly pass stdout & stderr streams instead of files

    * Ensure outputs are redirected to the correct streams

    * Fix unittests

    * Update conans/test/functional/toolchains/cmake/test_cmake_toolchain.py

    Co-authored-by: Carlos Zoido <mrgalleta@gmail.com>

    * Remove unused method

    * Add cmake.test stdout test, fix failing test

    * Simpify testing

    * Change testing approach for build

    * Change testing approach for build

    * Finally fix tests (hopefully)

    * Simplify tests

    * Comment wording

    * Check for emptyness in Windows

    ---------

    Co-authored-by: Carlos Zoido <mrgalleta@gmail.com>

commit 71d863a
Author: James <james@conan.io>
Date:   Wed Nov 29 17:17:48 2023 +0100

    poc for filtering lists with profile-like inputs (conan-io#14694)

    * poc for filtering lists with profile-like inputs

    * per-package and options and distance

    * wip

    * wip

    * wip

    * refactor list format compact

    * wip

    * wip

    * ready

    * fix test

    * fix tests

    * converted to graph find-binaries approach

    * wip

    * review

    * Create custom formatters to ensure we can expand the command in the future

    * review

    ---------

    Co-authored-by: Rubén Rincón <rubenrb@jfrog.com>

commit 25070c1
Author: Luis Caro Campos <3535649+jcar87@users.noreply.github.com>
Date:   Wed Nov 29 14:02:38 2023 +0000

    Cleanup pyinstall.py (conan-io#15188)

commit 29e9f95
Author: James <james@conan.io>
Date:   Wed Nov 29 10:58:08 2023 +0100

    proposal for deploy() feature (conan-io#15172)

    * proposal for deploy() feature

    * rename argument --deploy-package

    * rename arg

commit f0a1b35
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Tue Nov 28 15:45:17 2023 +0100

    Fix serialization of tool_requires in `conan profile show --format=json` (conan-io#15185)

    * Fix serialization of tool_requires in profile show --format=json

    * Serialize recipe reference as repr in profile tool_requires

    * Fix test

commit a5605d1
Author: James <james@conan.io>
Date:   Tue Nov 28 14:29:54 2023 +0100

    Refactor ``conan list --format=compact`` format code (conan-io#15177)

    * refactor list format compact

    * wip

    * wip

commit 2e56813
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Mon Nov 27 16:47:23 2023 +0100

    Add test showing that `configure()` can be used to set `deprecated` (conan-io#15180)

    Add test showing that configure can set deprecated option just fin

commit 65ec31c
Author: Juan <35701596+juansblanco@users.noreply.github.com>
Date:   Sat Nov 25 08:01:42 2023 +0100

    Removed conan migration compatibility warning (conan-io#15174)

    removed warning and related test

commit dde76f6
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Fri Nov 24 19:20:32 2023 +0100

    Fix `conan graph info --format=text` being printed to stderr (conan-io#15170)

    Fix graph info --format=text being printed to stderr

commit 0d9f52f
Author: Rubén Rincón Blanco <rubenrb@jfrog.com>
Date:   Fri Nov 24 07:00:27 2023 +0100

    Allow querying the contents of settings.yml (and settings_user!) from ConfigAPI (conan-io#15151)

    * Allow querying the contents of settings.yml (and settings_user!) from the API

    * Add tests

    * Pretty print settings, make ConfigAPI.builtin_confs a @Property

    * Fix tests, ensure null is properly printed

    * Remove conan config settings command until it's asked by someone

    * Remove unneeded test

    * Remove unused import
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[feature] Add a deploy() method to conanfile for application specific deployment logic
5 participants