HEX
Server: Apache
System: Linux pdx1-shared-a1-38 6.6.104-grsec-jammy+ #3 SMP Tue Sep 16 00:28:11 UTC 2025 x86_64
User: mmickelson (3396398)
PHP: 8.1.31
Disabled: NONE
Upload Files
File: //usr/local/wp/vendor/wp-cli/entity-command/features/user-meta.feature
Feature: Manage user custom meta fields

  Scenario: Usermeta CRUD
    Given a WP install

    When I run `wp user-meta add 1 foo 'bar'`
    Then STDOUT should not be empty

    When I run `wp user-meta get 1 foo`
    Then STDOUT should be:
      """
      bar
      """

    When I try `wp user-meta get 2 foo`
    Then STDERR should be:
      """
      Error: Invalid user ID, email or login: '2'
      """
    And the return code should be 1

    When I run `wp user-meta set admin foo '[ "1", "2" ]' --format=json`
    Then STDOUT should not be empty

    When I run `wp user-meta get admin foo --format=json`
    Then STDOUT should be:
      """
      ["1","2"]
      """

    When I run `wp user-meta delete 1 foo`
    Then STDOUT should not be empty

    When I try `wp user-meta get 1 foo`
    Then the return code should be 1

    When I run `wp user meta add 1 foo bar`
    And I run `wp user meta add 1 foo bar2`
    And I run `wp user meta add 1 foo bar3`
    Then STDOUT should not be empty

    When I run `wp user meta delete 1 foo bar2`
    And I run `wp user meta list 1 --keys=foo --format=count`
    Then STDOUT should be:
      """
      2
      """

    When I run `wp user meta delete 1 foo`
    And I run `wp user meta list 1 --keys=foo --format=count`
    Then STDOUT should be:
      """
      0
      """

  Scenario: List user meta
    Given a WP install

    When I run `wp user meta set 1 foo '[ "1", "2" ]' --format=json`
    Then STDOUT should not be empty

    When I run `wp user meta list 1 --format=json --keys=nickname,foo --fields=meta_key,meta_value`
    Then STDOUT should be JSON containing:
      """
      [{"meta_key":"nickname","meta_value":"admin"},{"meta_key":"foo","meta_value":"a:2:{i:0;s:1:\"1\";i:1;s:1:\"2\";}"}]
      """

    When I run `wp user meta list 1 --format=json --keys=nickname,foo --fields=meta_key,meta_value --unserialize`
    Then STDOUT should be JSON containing:
      """
      [{"meta_key":"nickname","meta_value":"admin"},{"meta_key":"foo","meta_value":["1","2"]}]
      """

    When I run `wp user meta list 1 --keys=nickname,foo`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value                          |
      | 1       | nickname | admin                               |
      | 1       | foo      | a:2:{i:0;s:1:"1";i:1;s:1:"2";}      |

    When I run `wp user meta list 1 --keys=nickname,foo --unserialize`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value     |
      | 1       | nickname | admin          |
      | 1       | foo      | ["1","2"]      |

    When I run `wp user meta list admin --keys=nickname,foo`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value                          |
      | 1       | nickname | admin                               |
      | 1       | foo      | a:2:{i:0;s:1:"1";i:1;s:1:"2";}      |

    When I run `wp user meta list admin --keys=nickname,foo --unserialize`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value     |
      | 1       | nickname | admin          |
      | 1       | foo      | ["1","2"]      |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=id --order=asc`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value                          |
      | 1       | nickname | admin                               |
      | 1       | foo      | a:2:{i:0;s:1:"1";i:1;s:1:"2";}      |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=id --order=asc --unserialize`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value     |
      | 1       | nickname | admin          |
      | 1       | foo      | ["1","2"]      |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=id --order=desc`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value                          |
      | 1       | foo      | a:2:{i:0;s:1:"1";i:1;s:1:"2";}      |
      | 1       | nickname | admin                               |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=id --order=desc --unserialize`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value     |
      | 1       | foo      | ["1","2"]      |
      | 1       | nickname | admin          |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=meta_key --order=asc`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value                          |
      | 1       | foo      | a:2:{i:0;s:1:"1";i:1;s:1:"2";}      |
      | 1       | nickname | admin                               |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=meta_key --order=asc --unserialize`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value     |
      | 1       | foo      | ["1","2"]      |
      | 1       | nickname | admin          |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=meta_key --order=desc`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value                          |
      | 1       | nickname | admin                               |
      | 1       | foo      | a:2:{i:0;s:1:"1";i:1;s:1:"2";}      |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=meta_key --order=desc --unserialize`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value     |
      | 1       | nickname | admin          |
      | 1       | foo      | ["1","2"]      |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=meta_value --order=asc`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value                          |
      | 1       | nickname | admin                               |
      | 1       | foo      | a:2:{i:0;s:1:"1";i:1;s:1:"2";}      |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=meta_value --order=asc --unserialize`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value     |
      | 1       | nickname | admin          |
      | 1       | foo      | ["1","2"]      |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=meta_value --order=desc`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value                          |
      | 1       | foo      | a:2:{i:0;s:1:"1";i:1;s:1:"2";}      |
      | 1       | nickname | admin                               |

    When I run `wp user meta list admin --keys=nickname,foo --orderby=meta_value --order=desc --unserialize`
    Then STDOUT should be a table containing rows:
      | user_id | meta_key | meta_value     |
      | 1       | foo      | ["1","2"]      |
      | 1       | nickname | admin          |

  Scenario: Get particular user meta
    Given a WP install

    When I run `wp user create testuser testuser@example.com --description='This is description' --porcelain`
    Then STDOUT should be a number
    And save STDOUT as {USER_ID}

    When I try the previous command again
    Then the return code should be 1

    When I try `wp user-meta get {USER_ID} description`
    Then STDOUT should be:
      """
      This is description
      """