首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Faker gem生成2-3个字母串

Faker gem生成2-3个字母串
EN

Stack Overflow用户
提问于 2019-03-15 18:26:32
回答 3查看 241关注 0票数 1

Faker gem生成简短的无意义字符串,而不是所描述的字符串。例如,Faker::Job.title生成"et"。如果我有一个功能测试,希望在页面上找不到Faker生成的字符串,如果字符串是"et“,那么它很可能会失败。这肯定是意想不到的行为,因为世界上没有人有"et"这个头衔。

这是我的代码,我最近一次检查它的标题是预期的,但角色和类别不是:

代码语言:javascript
复制
# frozen_string_literal: true

shared_context 'with signatory attributes' do
  let(:first_name)   { Faker::Name.first_name }
  let(:last_name)    { Faker::Name.last_name }
  let(:email)        { Faker::Internet.email }
  let(:title)        { Faker::Job.title }
  let(:mobile)       { Faker::Number.number(10) }
  let(:employee_num) { Faker::Number.number(10) }
  let(:role)         { Faker::Job.title }
  let(:category)     { Faker::Job.title }
end
EN

回答 3

Stack Overflow用户

发布于 2019-03-15 22:29:33

看起来Faker并不打算做一个现实的工作头衔。但是,你很容易就能随意地给自己定个职位。我将只对您自己的自定义数组进行示例,如下所示:

代码语言:javascript
复制
let(:title) { %w[Admin Manager Engineer].sample }
票数 1
EN

Stack Overflow用户

发布于 2019-03-15 18:34:19

它似乎出于某种原因从Lorem Ipsum String Set中提取字符串。你介意分享你的代码吗?

票数 0
EN

Stack Overflow用户

发布于 2019-03-15 19:39:08

您可以使用具有单词边界的regex matcher,而不是仅使用短字符串,但它仍然不是万无一失的。

代码语言:javascript
复制
let(:first_name)   { /\b#{Faker::Name.first_name}\b/ }

但也许更好的做法是将属性存根到模型本身,并在被调用时引发错误。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55180495

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档