在 upwork 上找了个兼职, 和老板起冲突了, 大家来吃瓜

2022-07-04 17:59:26 +08:00
 FaiChou

五月初在 upwork 上有个工作推送给我, 老板是德国人, 要做一个项目, 进行了一次电话交流, 最后签了合同, 合同上写 7 月 30 号之前要做一个 app 出来, 当时老板的想法是做一个喝水 app, 提醒喝水, 再加上硬件 BLE 控制的智能水杯(BLE 这块不是我负责). 项目是用 ReactNative 来做, 后台用的 Firebase, 很少有接口, 前端直接操作 Firestore(读写 db), 项目团队初期是有一个后台, 一个负责硬件 BLE 的, 一个 UI, 还有俩负责前端(iOS+Android).

前端另一个哥们 RN 写的不多, 写了一点功能, 然后就离开了项目. 前端项目基本都是我做的, 包括搭建整个项目, 集成各种第三方库, 打包分发(包括 codepush), 还有 90%以上的页面.

介绍下我吧. 我想找一个兼职, 每周干 20 小时, 赚点外快, 我写过几个 RN 项目, 可以说有个 2 年的 RN 开发经验(从我的 github 上可以看出来), 和老板签的合同是 $20/hours.

经过几次开会, wireframe(原型图) 变得越来越复杂, 不仅仅是一个喝水类 app, 变成了养宠物为主要功能, 喝水 /咖啡 /维他命用来喂养宠物, 进行一些挑战(喝水 /步数挑战等)可以解锁新宠物, 有商店, 可以花钱买宠物(in app purchase), 买各种宠物的配件(墨镜 /鞋子 /帽子), 当然提醒喝水的功能也是有的. 宠物在首页是动画的, 我推荐用 LottieView, 用起来也没有任何问题. 当然开会也说过要加 NFT 和 AI 识别喝的什么饮料. 然后被我们 pass 掉了.

项目管理用的 Monday, 交流用 slack, UI 用的 Figma, 每周至少一次视频会议, 最近几次都是晚上九点开到晚上十一点半.

冲突 1:

开发初期, 老板找了一个印度人 A, 负责整个团队的技术, 他比较擅长 backend, 但到目前做的东西就是在给我提 bug, 项目逻辑都搞不懂, 初期我照着原型图做的 app 就给我找 UI bug. 后来他和后端哥们也起了一次冲突, 没经过后端哥们的同意, 改了代码, 而且没有测试, 直接提交了代码, 然后给后端哥们说: "我改了你的代码, 你测试下有没有问题". 后来后端哥们把他教育了, 最后印度人 A 承认了:

To be honest, this is my first official project of firebase. I do follow in my normal project. I did 1 project for learning purpose before 2 years so didn't understand firebase methodology so well.

冲突 2:

条形码识别的问题, 那天我刚开发完条形码识别的功能, 因为是用的第三方 api, 所以我让后端调用这个 api, 提供一个接口给前端用, 我把功能都实现了. 结果晚上赶上开会, 我还没有测试充分, 老板让印度人 A 给他演示一下, 结果扫了很多商品都不能成功. 于是老板很生气, 说了很多 F word. 把责任都怪我头上. 其实就是第三方 api 的问题, 测试的 key 不给正常商品的返回结果, 而付费的 key 老板也没有买, 后端只是 wrap 了一层, 也没给我一些错误信息. 第二天又和我 video call, 我俩互相说了一些 F word, 他一直觉得 progress 又问题, 一直让我给他承诺什么时候能做完某一大部分的功能. 于是我让他在 Figma 上面给我过一遍需求, 结果走了几步就走不通, 这上面全是 unclear 的逻辑. 没有一个 project manager 来做详细的功能设计. 没有需求设计也没有开发设计, 这就是这个项目最大的问题, 我给老板也解释了, 我只是个 coder, 不想参与这些功能需求的设计.

冲突 3:

老板觉得项目进度有问题, 让我推荐个人, 我推荐了我的朋友, 结果他没邀请我的朋友来, 而是直接找了一个印度人 B, 这个人号称 6 年 RN 开发经验. 在上周的第一次会议上, 直接对我的代码进行 code review, 提了一大堆小问题, 问题有:

  1. 把所有 png 替换成 svg
  2. 不能使用 Context 应该使用 Redux, 如果大型项目 Context 不利于维护
  3. 删掉 src/images 文件夹, 用 src/Assets/images
  4. 尽量抽离 component 出来, 使其 resuable
  5. 删掉 src/tools 使用 src/Utils

等等一系列这种问题. 确实 svg 换成 png 比较节省存储并清晰度会有提升. 但其余的都是个人开发的习惯而已, 对于第四条可复用的组件, 这更是模棱两可的话题, 比如组件抽离出来要写更多的代码去维护, 写更多的属性去控制, 就没有必要去抽离了, 对于一些公共的组件, 我已经做了一大部分的公用抽离.

但是老板不懂技术, 老板听后, 直接炸锅了, 问我为什么不一开始就做好? 他觉得我这代码有很严重的问题.

冲突 4:

上上周有个印度人 C 的加入, 应该是个实习生, git rebase 不会用, 开始解决了几个 bug, 但是没有测试充分, 却引来了其余的 bug. 提交代码前也没有 lint 代码, 我花了一些时间去 check 他的代码.

印度人 B 又新推了一个方案, 提交代码前创建分支, 然后提交 PR 给她, 她来合并或者 reject. 于是我就说, 咱这项团队规模不适合这种, 直接开发提交更快, 并不会有什么问题, 提交 PR 检查费时, 它适合开源项目或者团队规模比较大的项目.(当然的确有利于项目规范), 于是我艾特了群里其他几位, 另外两位印度人表示赞同 PR..

冲突 5:

我想退出项目不干了, 因为很明显老板想让 B 取代我, 而且其余几个印度人也一直挤兑. 但是老板想把钱全要回去, 在 upwork 上开 case. 因为合同里写的是七月 30 号要上线, 我这违约. 并且不满意我的代码 老板直接说, 其他三位开发者都对我的代码不满意.

我做了哪些功能呢?

  1. 登陆注册(邮箱 /谷歌 /FB 登陆)
  2. 完善个人信息(姓名 /年龄 /身高体重 /运动量 /喝水目标)
  3. 欢迎页(有个动画)
  4. 首页宠物动画
  5. 挑战逻辑(发起喝水挑战完成挑战)
  6. 添加喝水(直接列表添加或者扫码)
  7. 夜晚模式(所有页面支持(
  8. i18n (GER 和 ENG)
  9. 商店页面(商店列表, 购买宠物, payment 这块没有做)
  10. 宠物管理页面(命名宠物 /宠物列表 /切换宠物)
  11. 推送通知功能
  12. 运动数据获取(Google Fit/Apple Health)

截图几张证据:

  1. 老板想退全款: https://i.imgur.com/yEGrHTH.png
  2. 关于 PR 的讨论: https://i.imgur.com/FzsPF1n.png
  3. 和老板的一些谈话: https://i.imgur.com/OSind3h.png
  4. 合同的一点内容: https://i.imgur.com/0yAUtRS.png

现在我的感觉是:

  1. 老板想白嫖我的工作
  2. 印度人 B 是印度人 A 找来的

我的问题:

老板肯定会在 upwork 上开 case, 我已经提现过两次了(upwork 直接打款到我的国内银行). 这钱真能要回去? 我的 upwork 账号肯定受影响, 这我已经了解.

18237 次点击
所在节点    职场话题
111 条回复
FaiChou
2022-07-04 18:01:26 +08:00
我想尽量不要让老板对在 upwork 上的中国开发者产生误解. 但也要充分保护自己的利益. 我不能接受全款退款.
hvsy
2022-07-04 18:09:32 +08:00
@FaiChou 印度的开发者要价很低的, 这才是关键.
FaiChou
2022-07-04 18:15:52 +08:00
再补充下 印度人 B, 她从没写过项目代码, 来就直接给项目整改:

bxb100
2022-07-04 18:18:27 +08:00
这合同完全没限制甲方的权利,你不按时上架就是违约?
simonh8
2022-07-04 18:20:47 +08:00
歪个楼,楼主是怎么学的英语
FaiChou
2022-07-04 18:24:32 +08:00
@simonh8 我靠.. 你和老板名字一样. 刷刷美剧就好, 我现在主要职业是做外贸.


@bxb100 问题也在这, 合同在 upwork 上也有一份, 他在 upwork 上开 case, upwork 方肯定也是按照合同来. 但是 app 一开始说的和最终要做的完全不一样. 功能完全不是一个数量级的. 我是不是应该提前收集一些证据? 把他之前的想要做的东西和最终要做的不一样, 收集起来.
join
2022-07-04 18:26:48 +08:00
尽早止损,不要浪费时间再掰扯,不要在意 upwork 声誉。upwork 本来就乱七八糟的,都是一些不靠谱的客户。
看样子就是两方为了省钱,最后搞出一堆因为省钱而产生的破事。
leokino
2022-07-04 18:27:14 +08:00
$20/hr 还想要 full refund 真的无语。code quality 不是你的问题的。只要你有 output ,而且代码本身可以运行,所谓的 code quality 本身就是用更多时间换来的,速度和质量不可兼得,你这个老板的预期有问题。
FaiChou
2022-07-04 19:15:06 +08:00
@leokino “而且代码本身可以运行” 虽然没错, 现在开始按照细节找茬了, 像素级找问题:

bigShrimp8577
2022-07-04 19:19:20 +08:00
就这工作量也不像一个简单的喝水 app ,我前不久也接个简单的活,本来以为就一简单的页面,预估的工时就短,结果一做发现有些隐藏的需求,大大超出我预估的工时,后面越做越火气,按他反馈的意见改得七七八八后就直说这东西超出工时了,并且能改的我都改了,还有些是不想做的,因为最开始也没提这个功能,并且这个功能可能做下来都比我最开始预估的工时还长。我就说这一版能接受就接受,不能那这单算我白做。后来客户看了,啥意见也没说,让我发代码然后转钱。
FaiChou
2022-07-04 19:21:21 +08:00
@bigShrimp8577 你这听起来像 milestone 式的. 我这个按照工时的.
cszchen
2022-07-04 20:01:41 +08:00
冲突 4 ,我也赞同 pr ,多人开发如果都在一个分支,那不用干活了,时刻解决冲突
cszchen
2022-07-04 20:03:55 +08:00
尽早止损吧,这一看就是个坑,填不完。需求不清晰,没有合适的 pm ,还缺乏信任
toesbieya
2022-07-04 20:04:30 +08:00
说实话,你这一个页面和 UI 差的有点多
txoooy
2022-07-04 20:44:06 +08:00
楼主你做了这些就不到 1000 刀的收入吗 然后还被要求退款 ..
qiaobeier
2022-07-04 20:44:28 +08:00
实话说,如果不是赶时间,这个 ui 确实通不过 qa 。
wonderfulcxm
2022-07-04 20:52:21 +08:00
wtf ?杠回去
hackfly
2022-07-04 20:56:49 +08:00
设置里程碑就不会这么坑了吧
Froyo9
2022-07-04 21:05:32 +08:00
我和印度人合作过, 他们开会扯皮可以, 写代码真的不行.
FaiChou
2022-07-04 21:16:39 +08:00
@qiaobeier 的确很赶时间,其次 ui 可以修改,这也不是最终要上架的版本。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/864029

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX