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

feat(core): add model unit test #359

Merged
merged 8 commits into from
Nov 3, 2019
Merged

feat(core): add model unit test #359

merged 8 commits into from
Nov 3, 2019

Conversation

quirkyshop
Copy link
Collaborator

  • 增加model单测
  • 修复model dirty check比较方法
  • 增加model processing 初始值(置false流程未完成,TODO)
  • 修复hasChangedInSequence对于 { [x]: false } 仍然报错的问题
  • 修复unsafe_setSourceState 无法处理 product(state, (draft) => draft.a = 1))的写法,仿造setState修复

}

each(draftKeys.length > stateKeys.length ? draft : this.state, (value, key) => {
if (!isEqual(this.state[key], draft[key])) {
Copy link
Collaborator Author

Choose a reason for hiding this comment

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

eg. draft: { a: 1 } state { }
避免each时value永远是draft[key]

@@ -193,7 +195,7 @@ export const createStateModel = <State = {}, Props = {}>(
hasChangedInSequence = (key?: string) =>
key
? this.persistDirtys[key]
: Object.keys(this.persistDirtys || {}).length > 0
: Object.keys(this.persistDirtys || {}).filter(k => this.persistDirtys[k] === true).length > 0
Copy link
Collaborator Author

Choose a reason for hiding this comment

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

processFlag 变成 processCout 会更合理些,鉴于这个值会超过1,flag命名大多用来表示boolean

@janryWang janryWang merged commit e7edcfa into alibaba:v1 Nov 3, 2019
ZirkleTsing pushed a commit that referenced this pull request May 14, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants