Project

General

Custom queries

Profile

Actions

User story #25970

closed

Make compilation resolved loops over Blocks/Methods in techniques possible

Added by Félix DALLIDET 4 months ago. Updated 2 months ago.

Status:
Released
Priority:
N/A
Category:
rudderc
Target version:
UX impact:
Suggestion strength:
User visibility:
Effort required:
Name check:
To do
Fix check:
To do
Regression:
No

Description

Being able to loop/repeat a method|block call in a technique using parameterized local variables would be great.
The loops will be resolved at technique compilation, right before the starting from the leaf element when nested.

The proposed syntax is heavily inspired from the Ansible loops syntax https://docs.ansible.com/ansible/latest/playbook_guide/playbooks_loops.html#using-loops.

  - name: "Install a package" 
    method: package_present
    params:
      name: "${plouf.name}" 
      version: "${plouf.version}" 
    foreach:                 # field to force a loop
      - name: "vim" 
        version: "latest" 
      - name: "htop" 
        version: "2.3.4" 
      - name: "${technique_id.extra_package}" 
        version: "latest" 
    foreach_name: "plouf"    # loop iterator name, useful when loops are nested using blocks

Subtasks 2 (0 open2 closed)

User story #26116: Add Scala backend for technique loopsReleasedFrançois ARMANDActions
User story #26120: Make sure that bundle arity is always strict when resolving loopsReleasedAlexis MoussetActions

Related issues 3 (3 open0 closed)

Related to Rudder - Bug #26651: Compilation error when loop key with empty valueNewActions
Related to Rudder - Bug #26652: Compliance repeated when using the new “foreach” loopsPending releaseVincent MEMBRÉActions
Related to Rudder - Bug #26650: Tecnique loop copy box pastes wrong valueNewActions
Actions #1

Updated by Félix DALLIDET 4 months ago

  • Status changed from New to In progress
  • Assignee set to Félix DALLIDET
Actions #3

Updated by Félix DALLIDET 4 months ago

  • Status changed from In progress to Pending technical review
  • Assignee changed from Félix DALLIDET to Alexis Mousset
  • Pull Request set to https://github.com/Normation/rudder/pull/6049
Actions #4

Updated by Anonymous 4 months ago

  • Status changed from Pending technical review to Pending release
Actions #5

Updated by Vincent MEMBRÉ 3 months ago

  • Subtask #26116 added
Actions #6

Updated by Félix DALLIDET 3 months ago

  • Subtask #26120 added
Actions #7

Updated by Vincent MEMBRÉ 2 months ago

  • Status changed from Pending release to Released

This bug has been fixed in Rudder 8.3.0~alpha1 which was released today.

Actions #8

Updated by François ARMAND about 17 hours ago

  • Related to Bug #26651: Compilation error when loop key with empty value added
Actions #9

Updated by François ARMAND about 17 hours ago

  • Related to Bug #26652: Compliance repeated when using the new “foreach” loops added
Actions #10

Updated by François ARMAND about 17 hours ago

  • Related to Bug #26650: Tecnique loop copy box pastes wrong value added
Actions

Also available in: Atom PDF