Giáo trình Quản lý dự án phần mềm

pdf 243 trang hapham 2440
Bạn đang xem 20 trang mẫu của tài liệu "Giáo trình Quản lý dự án phần mềm", để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên

Tài liệu đính kèm:

  • pdfgiao_trinh_quan_ly_du_an_phan_mem.pdf

Nội dung text: Giáo trình Quản lý dự án phần mềm

  1. Quản lý dự án phần mềm 1
  2. Quản lý dự án phần mềm Mục lục Lời nói đầu 6 Ch•ơng 1. Nhập môn về quản lý dự án phần mềm Nhập môn 10 1.1. Nhu cầu đang gia tăng về phần mềm 10 1.2. Vai trò của việc quản lý trong phát triển phần mềm 11 1.3. Một thí dụ 13 1.4. Giành sự chấp nhận các thủ tục phát triển mới 15 1.5. Tóm tắt 17 Ch•ơng 2. Những vấn đề phát triển phần mềm Một chút phòng xa 19 2.1. Những vấn đề cơ bản 19 2.1.1. Những vấn đề liên quan đến các yêu cầu của dự án 20 2.1.2. Những thay đổi th•ờng xuyên 21 2.1.3. Dự toán và những vấn đề liên quan 21 2.1.4. Nguồn lực bên ngoài 22 2.1.5. Kết thúc một dự án phần mềm 23 2.1.6. Tuyển dụng nhân viên và thuyên chuyển 24 2.1.7. Theo dõi và giám sát 25 2.2. Phân tích rủi ro 25 2.2.1. Dự kiến những vấn đề cần giải quyết 26 2.2.2. Pha phân tích 27 2.2.3. Thực hiện các kế hoạch đối phó bất ngờ 29 2.3. Tóm tắt 31 Bài tập 32 Ch•ơng 3. Phát triển phần mềm theo hợp đồng Quan hệ khách hàng - nhà phát triển 33 3.1. Chi phí cộng thêm đối lại với giá cố định 33 3.1.1. Hợp đồng phí cộng thêm 34 3.1.2. Hợp đồng giá cố định 36 3.2. Các mối quan hệ khác gi•ã khách hàng - nhà phát triển 37 3.3. Yêu cầu đối với một đề xuất (RFP) 38 3.3.1. Một số vấn đề cơ bản 39 3.3.2. Chuẩn bị của RFP 39 3.3.3. Phát yêu cầu đề xuất RFP 42 3.4. Đề xuất 43 3.4.1. Đề xuất không do yêu cầu 43 3.4.2. Đề xuất khi có yêu cầu 44 3.4.3. Đội ngũ chuẩn bị đề xuất 44 3.4.4. Khuân dạng đề xuất 45 3.4.5. Khẳng định công việc (SOW) 48 3.5. Duyệt xét đề xuất và quá trình lựa chọn 49 3.5.1. Ban tuyển chọn đề xuất 49 2
  3. Quản lý dự án phần mềm 3.5.2. Ph•ơng pháp đánh giá đề xuất 50 3.6. Một số nhận định bổ sung về đề xuất 52 3.6.1. Những vấn đề liên quan đến khách hàng 52 3.6.2. Những vấn đề liên quan đến ng•ời đề nghị 53 3.7. Tóm tắt 54 Bài tập 55 Ch•ơng 4. Chu trình phát triển phần mềm Các biểu thái về chủ đề thác n•ớc 57 4.1. Pha quan niệm 60 4.1.1. Bàu không khí trong pha quan niệm 61 4.1.2. Những vấn đề trong pha quan niệm 62 4.2. Pha yêu cầu phần mềm 62 4.2.1. Bàu không khí trong quá trình pha yêu cầu 63 4.2.2. Các vấn đề trong pha yêu cầu 63 4.3. Pha thiết kế 65 4.3.1. Bàu không khí trong pha thiết kế 66 4.3.2. Những vấn đề trong pha thiết kế 67 4.4. Pha thực hiện 68 4.4.1. Bàu không khí trong pha thực hiện 70 4.4.2. Những vấn đề trong pha thực hiện 70 4.5. Pha tích hợp và thử nghiệm 71 4.5.1. Bàu không khí trong pha tích hợp và thử nghiệm 73 4.5.2. Những vấn đề trong pha tích hợp và thử nghiệm 74 4.6. Pha bảo trì 75 4.6.1. Bàu không khí trong pha bảo trì 76 4.6.2. Những vấn đề trong pha bảo trì 77 4.7. Tóm tắt 78 Bài tập 79 Ch•ơng 5. Nguyên tắc quản lý các kỹ s• phần mềm Họ có thực có gì khác nhau không ? 80 5.1. Cơ cấu tổ chức dự án phần mềm 81 5.2. Cơ cấu đội ngũ 85 5.2.1. Lãnh đạo đội 85 5.2.2. Các đội dân chủ 87 5.2.3. Các đội kỹ s• tr•ởng 87 5.2.4. Các đội chuyên gia 88 5.3. Các kỹ thuật báo cáo cơ bản 89 5.3.1. Báo cáo tình hình 90 5.3.2. Các cuộc họp về tình hình dự án 91 5.4. Những đ•ờng lối chung trong quản lý các kỹ s• phần mềm 92 5.5. Tóm tắt 94 Bài tập 95 Ch•ơng 6. Chia để trị các dự án lớn thế nào: phân chia và chiếm lĩnh. 3
  4. Quản lý dự án phần mềm Nhu cầu lớn không có nghĩa khó 96 6.1. Tinh chế từng b•ớc một 96 6.1.1. Phân giải chức năng 98 6.1.2. Phân giải thiết kế 99 6.2. Cơ cấu phân tích công việc 102 6.2.1. Phân giải dự án 103 6.2.2. WBS làm công cụ quản lý dự án 105 6.3. Xử lý những dự án lớn 106 6.3.1. Các hệ thống phụ 106 6.3.2. Đ•ờng lối phân giải chức năng 108 6.3.3. Đ•ờng lối phân giải thiết kế 109 6.3.4. Đ•ờng lối phân giải nhiệm vụ công việc 110 6.4. Tóm tắt 111 Bài tập 112 Ch•ơng 7. Các chức năng hỗ trợ dự án Hỗ trợ quản lý dự án 115 7.1. Kiểm tra cấu hình phần mềm (SCC) 116 7.1.1. Thuật ngữ kiểm tra cấu hình 118 7.1.2. Nguồn lực kiểm tra cấu hình 119 7.1.3. Kế hoạch quản lý cấu hình phần mềm 121 7.1.4. Một số đ•ờng lối chung 123 7.2. Bảo đảm chất l•ợng phần mềm (SQA) 126 7.2.1. Cung cấp phần mềm có chất l•ợng 126 7.2.2. Nguồn lực kiểm tra chất l•ợng 128 7.2.3. Kế hoạch bảo đảm chất l•ợng phầm mềm 130 7.2.4. Độ đo chất l•ợng phần mềm 132 7.2.5. Một số đ•ờng lối chung 133 7.3. Thử nghiệm phần mềm 134 7.3.1. Các loại thử nghiệm phần mềm 135 7.3.2. Các thủ tục thử nghiệm chính thức 137 7.3.3. Một số đ•ờng lối chung 138 7.4. Tóm tắt 139 Bài tập 140 Ch•ơng 8. Tiêu chuẩn phát triển phần mềm Tiêu chuẩn phát triển: tai hại cần thiết 142 8.1. Tổng quan các tiêu chuẩn phát triển phần mềm 142 8.2. Tiêu chuẩn US DOD 2167 145 8.2.1. Tổng quan tiêu chuẩn 2167 146 8.2.2. Rà soát và kiểm toán 148 8.2.3. Mô tả hạng mục dữ liệu (DIDS) 148 8.2.4. Lấy kích th•ớc tiêu chuẩn 154 8.2.5. Lợi và bất lợi của tiêu chuẩn 2167 156 8.3. Các tiêu chuẩn công nghệ phần mềm IEEE 156 8.3.1. Tổng quan tiêu chuẩn IEEE 157 8.3.2. Phân loại IEEE về các tiêu chuẩn công nghệ phần 4
  5. Quản lý dự án phần mềm mềm 159 8.3.3. Lợi và bất lợi của tiêu chuẩn IEEE 159 8.3.4. So sánh các tiêu chuẩn IEEE và DOD 164 8.4. Các tiêu chuẩn Ada 164 8.4.1. Môi tr•ờng Ada 165 8.4.2. Tiêu chuẩn IEEE cho các Ada PDL 165 8.5. Các tiêu chuẩn phát triển phần mềm khác 166 8.6. Tóm tắt 167 Bài tập 168 Ch•ơng 9. Lập trình dự án Lập trình: vấn đề 170 9.1. Kế hoạch phát triển dự án 171 9.2. Các hoạt động theo lập trình và mốc 173 9.2.1. Danh mục hoạt động theo lập trình 174 9.2.2. Các cột mốc và đ•ờng mốc chủ yếu 176 9.3. Các biểu đồ Gantt 177 9.4. Các biểu đồ PERT và con đ•ờng tới hạn 180 9.4.1. Đ•ờng tới hạn 182 9.4.2. Các khối ch•ơng trình PERT và việc tăng c•ờng 182 9.5. Nhân sự lập trình 183 9.5.1. Qui mô đội ngũ phát triển 184 9.5.2. Kỹ năng và kinh nghiệm 187 9.5.3. Tháng của con ng•ời bất nghì 188 9.6. Lập lịch các nguồn lực 189 9.6.1. Lập lịch không gian làm việc 189 9.6.2. Thiết bị lập trình 190 9.6.3. Chủ bán các nhà thầu phụ 191 9.7. Kiểm chứng và cập nhật ch•ơng trình 192 9.7.1. Báo cáo định kỳ 192 9.7.2. Các hoạt động kiểm chứng khác 193 9.7.3. Cập nhật ch•ơng trình 193 9.8. Một số đ•ờng lối chung cho việc lập trình và qui hoạch 194 9.8.1. Tinh lọc danh mục hoạt động ban đầu 194 9.8.2. Giành đ•ợc phê chuẩn ch•ơng trình 195 9.8.3. Mối quan hệ giữa ch•ơng trình, tài nguyên, chất l•ợng và tính chức năng 197 9.9. Tóm tắt 198 Bài tập 199 Ch•ơng 10. Chuẩn bị dự toán: ph•ơng pháp và kỹ thuật Dự toán: vấn đề 200 10.1. Dự toán dự án 201 10.2. Dự toán từng b•ớc 202 10.2.1. Những thành phần đ•a khỏi giá 203 10.2.2. Những thành phần d• thừa kinh nghiệm 203 10.2.3. Những thành phần có một phần kinh nghiệm 205 5
  6. Quản lý dự án phần mềm 10.2.4. Phát triển mới 206 10.2.5. Phân tích chi tiết dự án ở mức rủi ro 206 10.3. Uớc định phát triển mới 207 10.3.1. Những ph•ơng pháp kiểu đầu (nguyên mẫu) 207 10.3.2. Những ph•ơng pháp thống kê 209 10.4. Mô hình chi phí xây dựng (Cocomo) 210 10.4.1. Mức nhân sự 210 10.4.2. Mức độ phức tạp 213 10.4.3. Yếu tố độ tin cậy 215 10.4.4. Môi tr•ờng phát triển 216 10.4.5. Các thứ hệ 218 10.4.6. Thuật toán dự toán phí 219 10.5. Chức năng phân tích điểm 221 10.5.1. Những b•ớc FPA cơ bản 221 10.5.2. ứng dụng của FPA 224 10.6. Dự toán là một lĩnh vực 225 10.7. Dự toán tài nguyên phần cứng 229 10.7.1.Tải trọng CPU 229 10.7.2. L•u trữ dự liệu 233 10.7.3. Tốc độ 236 10.8. Tổng phí không phát triển 238 10.9. Tóm tắt 239 Bài tập 241 Tham khảo 243 Tài liệu đọc thêm Lời nói đầu 6
  7. Quản lý dự án phần mềm Đây là cuốn sách về quản lý dự án phần mềm; nó không phải là một cuốn sách tiếp nữa về công trình phần mềm. Đã có nhiều cuốn sách tham khảo về công trình phần mềm (coi danh mục tham khảo ở cuối cuốn sách này). Mục tiêu của sách này là trình bày công việc phát triển phần mềm theo quan điểm của nhà quản lý chứ không phải theo quan điểm của nhà phát triển. Cuốn sách tập trung, trong một cuốn duy nhất nhiều thực tiễn và kỹ thuật quản lý phần mềm hiện đại đã đ•ợc phát triển và tinh lọc trong suốt thập kỷ qua. Quản lý dự án đ•ợc trình bày nh• là một kỹ năng lĩnh hội đ•ợc và chứ không phải nh• là của trời cho. Chắc chắn, việc quản lý dự án đòi hỏi tài năng quản lý, nh•ng bản thân tài năng không đ•ợc hữu hiệu. Việc vận dụng thiết thực các thủ tục phát triển phần mềm hiện đại đòi hỏi có các nhà quản lý chuyên nghiệp. Vì đây là cuốn sách thực hành (chứ không phải là một công trình lý thuyết) nên nhiều ph•ơng pháp và kỹ thuật đ•ợc mô tả không có cơ sở lý thuyết cho riêng nó. Tuy nhiên những tham khảo sẽ đ•ợc cung cấp suốt cuốn sách dành cho những ai quan tâm đến cơ sở lý thuyết. Danh mục kèm các tham khảo và tài liệu để đọc đ•ợc gợi ý có ở cuối cuốn sách này. Nhất thời, độc giả có thể thấy một số đoạn đ•ợc nhắc lại trong cuốn sách này. Sở dĩ có điều này là để giải quyết cái th•ờng đ•ợc gọi là tình huống năm ngón tay. Điều này xảy ra khi mỗi năm ngón tay của độc giả cần đ•ợc cài vào cuốn sách để đánh dấu trong khi độc giả l•ỡng lự giữa các ch•ơng nhằm bao quát đ•ợc một chủ đề đặc biệt. Cuốn sách này có giảm nhu cầu phải đánh dấu bằng cách lặp lại cái giải thích vắn tắt bất cứ chủ đề chủ yếu nào đ•ợc tham chiếu ngay dù chủ đề đã đ•ợc thảo luận chi tiết ở đâu đó. Suốt cuốn sách những hạng mục tháng công và năm công đã đ•ợc sử dụng thay cho các hạng mục cũ tháng ng•ời và năm ng•ời. Những từ này đ•ợc thảo luận chi tiết ở phần 9.5.3. Đối t•ợng đọc đ•ợc chủ định. Quản lý dữ án phần mềm: Một tiếp cận cho ng•ời thực hành đ•ợc chủ định cho đối t•ợng đa dạng. Tr•ớc hết và chủ yếu sách đ•ọc chủ định làm nguồn tham khảo cho các nhà quản lý dự án phần mềm đang thực thi nhiệm vụ quản lý và trên cơ sở đó nó đ•ợc sắp xếp sao cho đề tài chủ yếu bao quát ở mỗi ch•ơng (trừ ch•ơng 1). Điều này đ•ợc thảo luận thêm trong giải thích sau về việc bố trí nội dung sách. Cuối cùng, cuốn sách có thể dùng làm tham khảo cho các kỹ s• phần mềm muốn mở rộng kiến thức của minh sang những lĩnh vực quản lý dự án kỹ thuật. Bố trí của cuốn sách 7
  8. Quản lý dự án phần mềm Nói chung, m•ời ch•ơng của cuốn sách xuất hiện theo trình tự lôgíc và cung cấp cho việc đi đầu vào lĩnh vực quản lý dự án phần mềm. Tham khảo nhanh đặt ở cuối mỗi ch•ơng có dạng tóm tắt mở rộng. Tóm tắt này nhằm đ•ợc sử dụng nh• là để ghi nhớ lần nữa hay nh• là một nguồn thông tin ban đầu. Ng•ời đọc đ•ợc yêu cầu tìm cách làm một số bài tập ở cuối mỗi ch•ơng. Các bài tập này sẽ giúp ng•ời đọc hiểu đ•ợc nhiều ý t•ởng và kỹ thuật trình bày trong ch•ơng đó. Ch•ơng 1 đề cập quan niệm quản lý dự án phần mềm. Ch•ơng này cũng tham luận nhiều khó khăn mà các nhà quản lý dự án gặp trong việc giành hỗ trợ của bộ phận quản lý cấp trên để trình ra những thủ tục phát triển mới. Ch•ơng 2 tóm tắt vắn tắt nhiều vấn đề phát triển phần mềm chung nhất (sau này đ•ợc xây dựng trong suốt cuốn sách). Ch•ơng này đ•ợc chia làm 2 phần. Phần đầu giành cho độc giả không quen với những vấn đề cơ bản về quản lý phần mềm. Phần hai giành cho những ngành đang quản lý dự án cả mới và cả đã có kinh nghiệm. Phần này thảo luận ph•ơng pháp đấu tranh với những vấn đề đã thảo luận tr•ớc đây, gọi là phân tích rủi ro. Các nhà quản lý dự án có kinh nghiệm có thể bỏ qua ch•ơng 1 và phần đầu của ch•ơng 2. Ch•ơng 3 thảo luận việc phát triển phần mềm theo hợp đồng. Ch•ơng này mô tả các hợp đồng dự án phần mềm đ•ợc tiến hành nh• thể nào, các đề nghị ra sao. Một văn bản đề nghị nên đ•ợc xây dựng thể nào và nên thiết lập thế nào và những mối quan hệ giữa khách hàng và nhà sản xuất. Ch•ơng này cũng mô tả các yêu cầu về văn bản đề nghị (RFP) và quá trình lựa chọn sau khi các đề nghị đã đ•ợc đệ trình. Ch•ơng 4 mô tả chu trình cơ bản phát triển phần mềm, nhấn mạnh đến việc tiếp cận theo giai đoạn, phát triển phần mềm. Những ph•ơng pháp luận khác cũng đ•ợc thảo luận (nh• là tạo mẫu nhanh và mô hình xoắn ốc - Spiral). Những giai đoạn cơ bản đ•ợc mô tả theo quan điểm của ng•ời quản lý dự án nhấn mạnh đến không khí và những vấn đè của mỗi giai đoạn. Ch•ơng 5 trình bày một số những nguyên tắc cơ bản của việc quản lý con ng•ời. Ch•ơng này lựa ra một số những mặt đặc thù liên quan đến việc quản lý các kỹ s• phần mềm, chẳng hạn nh• sự khác nhau đáng kể về năng suất giữa các kỹ s• phần mềm và tính khí phong độ của các nhà lập trình nói chung. Ch•ơng 6 đề cập một trong những vấn đề khó khăn nhất của phát triển phần mềm: làm sao quản lý đ•ợc những dự án phần mềm lớn. Ch•ơng này giải thích những dự án lớn có thể đ•ợc phần chia thành những bộ phận nhỏ dễ quản lý nh• thế nào theo ph•ơng châm chia ra chế ngự. 8
  9. Quản lý dự án phần mềm Ch•ơng 7 mô tả ba trong những chức năng hỗ trợ quản lý cơ bản: kiểm tra cấu hình đảm bảo chất l•ợng và thử nghiệm phần mềm. Ch•ơng này cũng thảo luận mối quan hệ giữa những chức năng đó. Ch•ơng 8 trình bày tổng quan về các chuẩn phát triển phần mềm. Đặc biệt hai chuẩn đ•ợc thảo luận chi tiết: chuẩn 2167 của Bộ Quốc phòng Hoa Kỳ (DOD) và chuẩn IEEE về phát triển phần mềm. Những chuẩn khác, nh• chuẩn phát triển phần mềm của Anh và Châu Âu, cũng đ•ợc nhắc tới và so sánh. Ch•ơng 9 thảo luận việc lập lịch và kế hoạch phát triển dự án (PDP) và kỹ thuật lập lịch và lập kế hoạch đ•ợc mô tả, kể cả phác đồ Gantt và PERR cổ điển và cấu trúc phá hủy công việc (WBS). Ch•ơng 10 chứa một mô tả tăng c•ờng và chi tiết của một vài ph•ơng pháp và kỹ thuật chuẩn bị dự toán. Ch•ơng này gồm những ph•ơng pháp dự tính qui mô của dự án và lịch phát triển dự án cũng nh• dự toán kỹ thuật, chẳng hạn nh• các yêu cầu về đĩa và về bộ nhớ. Ch•ơng này cũng giải thích kinh nghiệm có thể đ•ợc sử dụng thế nào để cải tiến dự toán và mô tả các dự toán có thể đ•ợc hoàn thiện thế nào trong quá trình phát triển dự án tiến triển. Tri ân Các tiêu chuẩn DOD-STD 2167a và DOD-STD 2168 và các mô tả hạng mục dự liệu liên quan của Bộ Quốc phòng Hoa Kỳ đã đ•ợc tham chiếu và trích dẫn đ•ợc phép của Bộ Quốc phòng Hoa Kỳ, Bộ chỉ huy các hệ thống chiến tranh không gian và trên biển. Các tiêu chuẩn công nghệ phần mềm IEEE đã đ•ợc tham chiếu và những tài liệu sau đây đã đ•ợc trích dẫn đ•ợc phép của Viện tập đoàn kỹ s• điện và điện tử (IEEE). Phần nhập môn của F.Buckley cho bản in 1984 của IEEE về tiểu chuẩn công nghệ phần mềm IEEE. Phần nhập môn của J.Horch cho bản in 1987 của IEEE về tiểu chuẩn công nghệ phần mềm. IEEE stel 729 - 1983 IEEE stel 1022 - 1987 IEEE stel 830 - 1984 IEEE stel 990 - 1986 Giữ bản quyền mọi mặt @ Viện tập đoàn kỹ s• điện và điện tử. Tôi xin cảm ơn về sự giúp đỡ to lớn của Amir trong việc duyệt và tập hợp văn bản. Tôi cũng biết ơn về nhiều gợi ý có ích của Ông. Tôi cũng xin cảm ơn Sharon và Talya đã không xáo trộn bản thảo văn bản. Cuối cũng và quan trọng nhất, tôi xin hết sức cảm ơn động viên của Iril, nếu không văn bản đã chẳng bao giờ đ•ợc viết ra. Nhãn hiệu th•ơng mại Ada là nhãn hiệu đã đăng ký của Chính phủ Hoa Kỳ, Ada AJPO UNIX là th•ơng nhãn của tập đoàn điện thoại và điện báo Mỹ VMS là th•ơng nhãn của tập đoàn thiết bị số 9
  10. Quản lý dự án phần mềm MS-DOS là th•ơng nhãn của tập đoàn Microsoft PC-DOS là th•ơng nhãn của tập đoàn máy móc kinh doanh quốc tế BYB là th•ơng nhãn của nhóm Gordon. 10
  11. Quản lý dự án phần mềm Ch•ơng một Nhập môn về quản lý dự án phần mềm Nhập môn “Phần mềm là nơi trồng các giấc mơ và thu hái ác mộng một thế giới những ng•ời hóa sói và những viên đạn bằng bạc“ Trích dẫn này từ Brad cox (cox 1990) nhấn mạnh những quan tâm của các nhà quản lý dự án phần mềm hôm nay. Làm sao có thể kiểm tra đ•ợc con ng•ời hóa sói này d•ới chi tiết công nghệ phần mềm đây ? Liệu việc phát triển phần mềm có thật sự là một bộ phận công trình không ? Việc phát triển phần mềm có thể kiểm tra đ•ợc. Có những ph•ơng pháp những kỹ thuật nh•ng chuẩn và những công cụ khi đ•ợc vận dụng đúng đắn chúng sẽ thúc đẩy sự phát triển thắng lợi của dự án phần mềm. Đó không phải là những viên đạn bằng bạc xuyên qua trái tim của ng•ời hóa sói: chẳng có gì giữ thật ở trong cả. Những ph•ơng pháp này cung cấp một cách tiếp cận có hệ thống tới sự phát triển phần mềm bắt đầu là những giai đoạn qui hoạch ban đầu và kết thúc là việc cung cấp sản phẩm phần mềm cuối cùng. Cuốn sách này đề cập đến việc vận dụng những ph•ơng pháp hiện đại để quản lý các dự án phần mềm. Sách trình bày tiếp cận thực hành “làm thế nào đây” hơn là tiếp cận lý thuyết mặc dù có những tham khảo rộng rãi cho những ai quan tâm đến việc mô tả lý thuyết đằng sau các ph•ơng pháp. Mục tiêu chủ yếu là tập trung, trong chỉ một cuốn sách, mô tả biết bao công cụ và qui trình dính líu đến những hoạt động quản lý phần mềm nh•: Dự toán chi tiết dự án Chuẩn bị các lịch trình phát triển Vận dụng các tiêu chuẩn phát triên thiết thực Chuẩn bị và đánh giá các đề nghị Nhà quản lý dự án phần mềm theo thế đ•ợc cung cấp các ph•ơng pháp và qui tình cần thiết khiến cho việc phát triển phần mềm có hiệu quả hơn với ba mục tiêu nổi tiếng trong tâm t•ởng: phát triển phần mềm 1. theo ch•ơng trình 2. trong phạm vi ngân sách 3. theo yêu cầu 1.1. Nhu cầu đang gia tăng về phần mềm Thật có ít lĩnh vực công nghệ hiện đại lại không chứa phần mềm. Điều này bao gồm xe hơi, hàng không và vệ tinh cũng nh• thang máy, máy fax, truyền hình và các cơ quan điện tử. Phần mềm vận hành hệ thống an ninh xã hội, hệ thống chi l•ơng tập đoàn, và trái của nền kinh tế ph•ơng 11
  12. Quản lý dự án phần mềm Tây - Hệ thống thẻ tín dụng. Phần mềm đ•ợc sử dụng rộng rãi để viết và in sách. Việc gia tăng nhu cầu về phần mềm đã trở nên một vấn đề gay cấn. Nó đã gây ra việc gia tăng nhu cầu về kỹ s• phần mềm. V•ợt rất xa mức độ các nhà chuyên nghiệp phần mềm tốt nghiệp ở các tr•ờng đại học. Do đấy sự phát triển phần mềm đ•ợc yêu cầu có năng suất cao lợi hơn, tin cậy hơn và nói chung thành công hơn. Những yêu cầu mới đó có thể không đ•ợc đáp ứng ở những ph•ơng pháp phát triển thô thiển của những ngày đầu của máy vi tính. Những ph•ơng pháp mới đã đ•ợc đề xuất cải tiến đáng kể con đ•ờng mà phần mềm đ•ợc phát triển. Tính nghiêm trọng của vấn đề đã đ•ợc thừa nhận trong khắp cộng đồng công nghệ phần mềm. Một số các liên công ti và công xoexiom quốc tế đã đ•ợc thành lập ở Hoa Kỳ, Nhật Bản và Châu Âu với những ngân sách to lớn dành cho việc tìm kiếm những ph•ơng pháp giảm nhẹ (nếu không phải là loại trừ) vấn đề (coi Bennatan 1987). Cox (1990), trong một phân tích ph•ơng h•ớng công trình phần mềm sẽ tiến hành cho thấy rõ một cuộc cách mạng công nghiệp phần mềm lý thú, ông đã tiên đoán ngày mà các nhà lập trình sẽ thôi không mã hóa mọi thứ khi xóa và sẽ ghép các ứng dụng trừ những catalô l•u trữ tốt của các thành phần phần mềm sử dụng lại đ•ợc. Quan niệm này và những quan niệm cách mạng khác nh• phát triển phần mềm tự động (coi Frankel 1985) vẫn còn phải mất quãng đ•ờng dài tr•ớc khi trở thành những ph•ơng tiện thiết thực của phát triển phần mềm. Xu h•ớng tiến tới công trình phần mềm có máy tính hỗ trợ (CASE) đã tạo nên nhiều công cụ phát triển tự động nh•ng chẳng may thay những công cụ đó1 th•ờng mất nhiều thời gian không xứng với chúng, ở những lĩnh vực khác của công nghệ các hệ CAD/CAM2 tự động đã đang đ•ợc sử dụng để thiết kế và xây dựng các thành phần điện tử nh•ng phát triển phần mềm vẫn còn hoàn toàn là một cố gắng thủ công. Cho đến lúc mà phần mềm sử dụng lại và phát triển phần mềm tái tạo và tự động bắt đầu thay thế đ•ợc các kỹ s• phần mềm thì phần mềm vẫn còn tiếp tục do con ng•ời phát triển. Trong khi chờ đợi việc gia tăng theo yêu cầu về năng suất và thuần thục tay nghề và thắng lợi chung của phát triển phần mềm phải duy trì trách nhiệm vẫn phải là ở nhà quản lý dự án phần mềm. 1.2. Vai trò của việc quản lý trong phát triển phần mềm. Việc quản lý dự án có hiệu quả đòi hỏi nhiều tài năng và kỹ xảo. Tiêu chuẩn IEEE (IEEE 1987a) cho dịch nghĩa sau về quản lý dự án phần mềm. 1 Xem Tahvanainen và Smolander ‘An annotated CASE Bibliography (1990)’ 2 CAD và CAM là thiết kế có máy tính trợ giúp và chế tạo có máy tính trợ giúp. 12
  13. Quản lý dự án phần mềm Quản lý dự án phần mềm là quá trình qui hoạch, tổ chức, nhân sự điều khiển, kiểm tra và lãnh đạo dự án phần mềm. Rõ ràng để trở thành nhà quản lý dự án phần mềm tốt thì là nhà phát triển phần mềm tốt không còn đủ nữa. Có những kỹ xảo quản lý đặc biệt đ•ợc yêu cẩu• dụng ngay từ những giai đoạn đầu của dự án, chằng hạn nh• ở các lĩnh vực nh•: - Giám sát và kiểm tra Điều này bao gồm việc quản lý có hiệu quả các thành viên đội ngũ phát triển và đòi hỏi ý thức th•ờng xuyên về tình trạng thực của công việc của họ về dự án. - Qui hoạch Qui hoạch là một trong những hoạt động quản lý quan trọng nhất và bao gồm việc chuẩn bị dự toán tốt, duy trì lịch trình phát triển và bố trí nhân sự hiệu quả. - Quan hệ khách hàng Trong một số dự án, việc tiếp xúc với khách hàng là hoạt động quản lý chủ yếu. Điều này bao gồm viết tài liệu về yêu cầu của khách hàng, khống chế những thay đổi do khách hàng, sử lý việc tham gia của khách hàng vào quá trình phát triển, cung cấp báo cáo và tổ chức xét duyệt cùng trình diễn sản phẩm. - Vai trò lãnh đạo kỹ thuật Lãnh đạo kỹ thuật tốt th•ờng là một phẩm chất ao •ớc trong việc quản lý phần mềm có hiệu quả. Điều này th•ờng đòi hỏi khả năng cung cấp chỉ đạo trong giải pháp của các vấn đề kỹ thuật phát sinh trong quá trình phát triển dự án. Điều này không cần thiết có nghĩa là dự trữ chung bản thân một giải pháp đích thực. Những lĩnh vực quản lý này là vận dụng đ•ợc cho mọi thể loại dự án Công nghệ cao. Dù sao việc quản lý dự án phần mềm lại khó khăn hơn do sự thể là phát triển phần mềm ít có tính xác định hơn các lĩnh vực công nghệ khác. Điều này là do những dự án phần mềm ít đo l•ờng đ•ợc khó dự toán hơn và phụ thuộc nhiều hơn vào những nhân tố chủ quan của con ng•ời. Lịch sử phát triển phần mềm đầy rẫy những tr•ờng hợp mà mức độ nguồn lực đ•ợc yêu cầu đã đ•ợc qui hoạch và dự toán tốt. Phát triển phần mềm đã từ lâu đ•ợc nhận định là doanh nghiệp đầy rủi ro. Đã có nhiều tr•ờng hợp các dự án phần mềm v•ợt quá ngân sách ban đầu của chúng tới hai, ba hay thậm chí bồn trăm phần trăm. Một số đã phải bỏ bễ sau khi đã chi hết vốn cơ bản khi thấy rõ là dự toán ngân sách ban đầu không chỗ nào sát với chi phí phát triển thực sự. Trong những năm gần đây, đã có ý đồ tiêu chuẩn hoá qui trình phát triển phần mềm và tạo ra môi tr•ờng phát triển nghiêm ngặt trong đó các dự án phần mềm dễ dự toán và kiểm tra hơn. Dù sao, điều này đã dẫn đến một vấn đề mới các nhà sản xuất đã phàn nàn phải mất quá nhiều thời gian vào việc thiết lập t• liệu và quá ít cho xu h•ớng phát triển hiện nay. Rõ ràng là cần tìm đ•ợc địa bàn trung độ giữa hai thái cực trong dự án không có thể lập trình và dự toán và dự án tiêu chaủan quá mức, thu thập 13
  14. Quản lý dự án phần mềm t• liệu quá mức trong đó chi công sức quá đáng vào tổng phí và công việc giấy tờ. Khi phát triển phần mềm bắt đầu dĩnh dáng đến một bộ môin công trình thì những ph•ơng pháp luận phát triển một cách có hệ thống mới cũng bắt đầu xuất hiện3. Mục đích của những ph•ơng pháp luận mới đó là làm cho sự phát triển phần mềm thành công hơn. Nếu thắng lợi đ•ợc do theo mức độ của ba mục tiêu nói tr•ớc đây (theo lịch trình, trong phạm vi ngân sách, theo yêu cầu) thì sự thất bại hẳn có nghĩa là trong việc hoàn thành thậm chí một trong những mục tiêu đó. Dù sao, thành công và thất bại không phải là cái điều đ•ợc định nghĩa một cách dễ dàng. Đã có nhiều nghiên cứu cho thấy là thất bại của dự án cũng là một vấn đề của nhận thức (cos Linto và mantel 1990). Một dự án có thể đ•ợc nhận định là thất bại ở một môi tr•ờng trong khi ở môi tr•ờng khác dự án lại có thể đ•ợc nhận định là thắng lợi. Nói một cách đơn giản, một khách hàng có thể hài lòng với đầu ra của một dự án trong khi ng•ời khách khác lại không. Theo thế thành công hay thất bại của một dự án không chỉ liên quan đến ba mục tiêu phát triển cơ bản mà cả đến kỳ vọng của khách hàng. Sự không rõ ràng của quan niệm thất bại của dự án chắc chẵn có thể tránh đ•ợc nếu chỉ đặt ra một đích duy nhất. Đây là đích mà khách hàng đặt ra chứ không phải đội ngũ phát triển đặt ra. Điều đó có nghĩa là: Thành công hay thất bại của một dự án đ•ợc tối hậu xác định ở sự hài lòng của bên yêu cầu phát triển (nghĩa là khách hàng) Những quan niệm đó đ•ợc chứng minh trong thí dụ sau: 1.3. Một thí dụ: Thí dụ này cho thấy vài sai lầm quản lý thông th•ờng mà nó có thể cuối cùng dẫn đến thất bại của một dự án phần mềm. Dự án khởi sự với vài quyết định sai lầm cơ bản liên quan đến việc khởi hành dự án, đến l•ợt nó, nó lại dẫn đến nhiều quyết định sai lầm hơn khi dự án tiến triển. Công ty liên kết công nghệ (TAI) là một công ty chuyên môn hóa trong việc phát triển và chế tạo thiết bị truyền thông. TAI là một ban phần mềm lớn chịu trách nhiệm về sự phát triển phần mềm cho thiết bị truyền thông. Ng•ời quản lý ban phần mềm đã đ•ợc biết là quản lý công ty đang tìm kiếm một công ty phần mềm bền ngoài để phát triển một hệ thống bảo d•ỡng và thời gian cho TAI. Ban phần mềm của TAI đã chủ động nắm bắt ý kiến, chuẩn bị một đề nghị phát triển hệ thống và đệ trình quản lý công ty. Căn cứ ở đề nghị này hai tháng đ•ợc giành tham khảo ý kiến của ban nhân sự, ban tài chính và tr•ởng ban để xác định các yêu cầu của hệ thống. Đội ngũ phát triển sau đó phát triển hệ thống trong 6 tháng sau đó (toàn bộ thời gian phát triển 3 Xem Shaw (1990) về một thảo luận đầy đủ trên vấn đề tiến hoá của phần mềm trong bộ môn công trình học. 14
  15. Quản lý dự án phần mềm kể ra phải là 8 tháng). Ban phần mềm dự tính cần đội ngũ 4 ng•ời để cung cấp các yêu cầu và phát triển hệ thống. ý kiến sử dụng một công ty phần mềm bên ngoài đ•ợc gác lại và đề nghị của ban phần mềm đ•ợc quản lý công ty chấp nhận. Ngân sách phát triển đ•ợc thông qua để đáp ứng 2 năm r•ỡi nhân công hay 4 ng•ời trong 8 tháng. Ban phần mềm tiến hành lập đội ngũ dự án và chọn một ng•ời quản lý dự án, trong số các ng•ời quản lý dự án truyền thông để lãnh đạo đội ngũ này. Khi cuối đợt hai tháng ban đầu gần kề, nhà quản lý dự án thấy rõ là phải cần nhiều thời gian hơn để xác định và viết t• liệu về các yêu cầu. Ph•ơng án chọn lựa của nhà quản lý dự án là: 1. Hoặc là yêu cầu nói rộng thời gian và bổ sung ngân sách phát triển 2. Hoặc là sử dụng một phần những yêu cầu hiện có. Ng•ời quản lý ban muốn chứng minh là ban của mình có khả năng phát triển cả các hệ thông tin và phần mềm truyền thông đ•ợc lồng vào. Do đó ng•ời quản lý dự án và đội ngũ đã thúc chọn ph•ơng án 2. Điều này dựa trên tiền đề là nếu dự án bị chậm và v•ợt quá ngân sách thì dự án phải bị coi là thất bại và các hệ thống thông tin sau này hẳn sẽ phải đ•ợc hợp đồng với một công ty phần mềm bền ngoài. Tất cả các ban khác thấy có nhiều vấn đề chủ yếu của hệ thống. Nói tóm lại hệ thống thiếu cái mà công ty cần. Ban phần mềm đề nghị sửa chữa các sai sót và yêu cầu ngân sách cho việc phát triển một version cải tiến mới. Dù sao, sự bất bình đã đến mức mà quản lý công ty quyết định đ•a việc phát triển một hệ thống hòan toàn mới cho một công ty phần mềm bền ngoài. Công ty phần mềm đ•ợc lựa chọn phát triển thành công hệ thống. Ngạc nhiên là lần này kinh phí lại ít hơn là ngân sách mà ban phần mềm TAI yeue cầu để sửa chữa các sai sót trong hệ thống ban đầu. Thí dụ (có thật) này thuyết minh một số sai lầm chủ yếu trong quản lý dự án. - Kinh nghiệm trong một lĩnh vực phần mềm (các hệ viễn thông đ•ợc lồng vao) khong đủ cho việc phát triển thành công phần mềm ở một lĩnh vực hoàn toàn khác (hệ thông tin). - Nhà quản lý dự án nêu trách nhiệm cam kết vào lịch trình phát triển hay ngân sách tr•ớc khi dự án đ•ợc xác định đủ. Trong phần lớn tr•ờng hợp cam kết của công ty chỉ có thể có khi các yêu cầu đã đ•ợc kết luận. - Nếu yêu cầu của một dự án không đ•ợc đáp ứng thì việc tham gia vào lịch trình và ngân sách trở lên vô nghĩa. - Khách hàng hay ng•ời dùng sẽ không phải bao giờ cũng cung cấp đ•ợc những yêu cầu đúng (thí dụ chủ yếu giao liên ban). Th•ờng là trách nhiệm của ng•ời sản xuất phải hỏi những câu hỏi thích đáng nhằm thu thập thông tin cần thiết. - Đôi khi tốt nhất là nên phát triển một hệ thống mới bằng việc xóa bỏ còn hơn là tìm cách cứu vãn một hệ thống đã đ•ợc phát triển tồi. 15
  16. Quản lý dự án phần mềm 1.4. Giành sự chấp nhận các thủ tục phát triển mới. Một trong những trở ngại mà các nhà quản lý dự án th•ờng phải khắc phục là tình trạng thiếu hỗ trợ ở quản lý cấp cao hơn đối với những ph•ơng pháp phát triển hiện đại. Vận dụng các ph•ơng pháp luận hiệu quả không dễ khi quản lý cấp cao hơn còn tranh luận về nhu cầu của họ. Điều này dẫn đến các nhà quản lý dự án đến một tình trạng tiến thoái l•ỡng nam, làm sao chấp nhận đ•ợc cái mà họ tin là tốt nhất trong khi vẫn giữ đ•ợc c•ơng vị nhà quản lý dự án. Rõ ràng là nhiều ph•ơng pháp và kỹ thuật đ•ợc mô tả trong cuốn sách này chỉ có hiệu lực khi chúng đ•ợc sử dụng. Mục tiêu của phần này là giúp nhà quản lý dự án giành đ•ợc sự chấp nhận ở quản lý cấp cao hơn trong việc ứng dụng những ph•ơng pháp mới. Quản lý cấp cao hơn (và đôi khi là các kỹ s• phần mềm khác) có khi dùng những lập luận sau chống lại việc sử dụng các ph•ơng pháp luận phát triển phần mềm hiện đại. 1. Những ph•ơng pháp mới này đều là lý thuyết trong “thế giới thực” sự việc diễn ra khác. 2. Những nhà quản lý dự án quá hình thức chủ nghĩa; họ đòi hỏi mọi thứ bằng văn bản và không đồng ý về mọi thay đổi nhỏ. 3. Chúng ta không có thì giờ cho mọi công việc giấy tờ đó. 4. Chúng ta không thể mất công sức về sự xa phí trong mọi qui trình dài dặc đó. Chúng ta vẫn luôn phát triển đ•ợc phần mềm mà chẳng cần những tổng phí đó. 5. Đây là kinh doanh chứ không phải tr•ờng đại học. Chúng ta mất tiền và mất khách nều chúng ta bắt đầu với việc lãng phí thời gian vào mọi ph•ơng pháp đó. 6. Ph•ơng pháp là tốt, nh•ng bất hạnh là bây giờ không phải lúc thực hiện chúng. Chúng ta mong rằng có thể sử dụng chúng một ngày nào đó nh•ng không phải đúng lúc này. 7. không có kỹ s• nào của chúng ta quen với những ph•ơng pháp mới này. Nh• thế sẽ mất nhiều thời gian và mất nhiều kinh phí để bắt đầu đào tạo lại họ. Sau đây là một số trả lời gợi ý cho những lập luận trên. 1. Hồ sơ phát triển phần mềm trong thế giới thực ch•a phải là quá tốt. Trên thực tế, các ph•ơng pháp cổ th•ờng chỉ dẫn đến thảm họa. Có thành công đấy nh•ng tỷ số thành công so với thất bại lại quá thấp. Bất cứ ph•ơng pháp thiết thực nào đều có đôi chút lý thuyết đúng nh• những ph•ơng pháp phát triển phần mềm đó những ph•ơng pháp đó đã đ•ợc các công ty t•ơng tự khác vận dụng thành công và đã giảm mạnh kinh phí phát triển phần mềm và tăng đáng kể chất l•ợng phần mềm. 2.Việc duy trì nề nếp hồ sơ viết là có lợi cho mọi ng•ời cho đội ngũ phát triển cho khách hàng và cho quản lý cấp cao. Nó đảm bảo là những 16
  17. Quản lý dự án phần mềm giao tiếp miệng đ•ợc hiểu đúng đắn. Nếu những thay đổi hay các h•ớng dẫn khác không ghi thành văn bản và không đ•ợc chấp nhận, thì sự phát triển có thể tiến hành theo h•ớng sai không ai có thể chắc chắn là mọi thay đổi, cả lớn và nhỏ, sau này sẽ đ•ợc nhớ lại khi dự án hoàn thành. Danh mục thành văn bản các thay đổi đ•ợc chấp nhận giúp khả năng theo dõi và hạch toán. 3. Đây có thể là khiếu lại đáng l•u ý; công việc giấy tờ phải đ•ợc duy trì ở mức tổi thiểu (có khi nó quá mức). Dù sao, đáng ngạc nhiên là công việc giấy tờ có mức độ hiện nay thực sự lại tiết kiệm thời gian và không gây lãng phí. Chẳng hạn những quyết định không ghi thành văn bản th•ờng khi cần đ•ợc lặp đi lặp lại và những đặc tả nói miệng dẫn đến những lý giải gây tranh cãi. Việc thiếu t• liệu th•ờng mất nhiều thời gian nhất trong các pha thích hợp và thử nghiệm khi bản thiết kế hệ thống chỉ đ•ợc l•u trong trí nhớ của ng•ời. Cũng vậy, một dự án không thành văn bản là một ác mộng trong việc duy tu. Sau khi hoàn thành dự án, khi các nhà sản xuất đã phân tán đi, tất cả những gì còn lại là sản phẩm và t• liệu. Không có t• liệu sản phẩm không gì hơn là một bí mật. 4. Một câu hỏi cần phản ảnh là: liệu và đúng vậy liệu phát triển phần mềm của chúng ta đã thực sự thành công thế nào? Lập luận này đ•ợc thử thách tốt nhất với bộ hồ sơ t• liệu đ•ợc chuẩn bị cho biết những vấn đề mà công ty đã có kinh nghiệm ở những dự án tr•ớc. Mục tiêu là chứng minh tiếp cận mới với phát triển phần mềm đâu phải là xa xỉ mà là cần thiết. 5. Những lập luận khó đ•ơng đầu nhất khi có yếu tố sự thực trong chúng, đặc biệt khi công ty có định ý phát triển ph•ơng pháp luận mới của chính họ. Mổc dù nhiều công ty có tiến hành nghiên cứu trong công trình phần mềm điều này thật khó là cần thiết ở mọi công ty đã có những ph•ơng pháp luận những tiêu chuẩn và những h•ớng dẫn đ•ợc ghi thành văn bản thỏa đáng (coi IEEE 1987b) để cho chúng có thể đ•ợc vận dụng dễ dàng ở mọi công ty mà không cần thiết phải phát triển chúng lại. Mất khách hàng không chỉ do lịch trình phát triển kéo dài mà còn do chất l•ợng kém và nhu cầu kỹ thuật không đ•ợc thỏa mãn. Càng cần nghiêm lệnh hẳn về phía lịch trình phát triển lâu hơn chứ không phải về phía sản phẩm phần mềm tốt hơn. Nh• vậy, lịch trình phát triển ngắn th•ờng dễ bị lạc lối do thời gian bổ sung đòi hỏi để bổ chính sản phẩm phần mềm kém cỏi, sau khi đã tung nó ra lần đầu (coi thí dụ ở phần 1.3). 6. Tại sao lại ch•a làm ngay? Liệu có cơ sở thực sự nào cho việc kêu ca là thời gian thích hợp hơn sẽ xuất hiện sau này? Trái lại càng thêm thời gian và công sức đầu t• vào những ph•ơng pháp phát triển nghèo nàn thì lại càng khó mà thay đổi đ•ợc. Cái cách tốt nhất trả lời cho lập luận này là cung cấp những lý do kinh doanh để giải thích vì sao những ph•ơng pháp phát triển mới lại nêu đ•ợc chấp nhận càng nhanh càng tốt. Bộ hồ sơ đã chuẩn bị, nêu trong trả lời cho lập luận 4, sẽ có ích cùng với thông 17
  18. Quản lý dự án phần mềm tin thu thập từ các công ty khác. Mục tiêu là bày tỏ rằng những qui tình phát triển có thứ tự sẽ làm tăng chất l•ợng sản phẩm phần mềm của công ty trong khi giảm chi phí phát triển. 7. Tầm quan trọng của việc đầu t• trong đào tạo ít khi cần đ•ợc nêu: đây là một quan niệm đ•ợc chấp nhận rộng rãi. Lập luận này khó có thể bác bỏ khi các ph•ơng pháp phát triển mới đ•ợc đ•a ra coi nh• một thay đổi chủ yếu về ph•ơng h•ớng. Câu trả lời tốt nhất tùy thuộc ở tình hình thực tế. Nếu những ph•ơng pháp mới thực sự tiêu biểu cho thay đổi chủ yếu là ph•ơng h•ớng thì chắc chắn là công ty đã có thí nghiệm nhiều vấn đề phát triển phần mềm. Nh• thế câu trả lời cho các lập luận 4 và 5 là thích đáng. Nếu những ph•ơng pháp mới không thực sự tiêu biểu thay đổi chủ yếu về ph•ơng h•ớng thì điều này nêu đ•ợc chứng minh có sử dụng dữ liệu của các dự án tr•ớc đây. T• t•ởng cơ bản là chứng minh rắng mặc dù nhiều qui trình phát triển hiện nay là tinh vi, việc cải tiến đáng kể có thể đ•ợc thực hiện thông qua việc giới thiệu một số ph•ơng pháp mới. Mọi lập luận chống lại các ph•ơng pháp luận phát triển mới chỉ có thể bác bỏ đ•ợc sau khi có chuẩn bị đầy đủ. Điều này th•ờng nghĩa là: - S•u tập dữ liệu về các dự án phát triển phần mềm tr•ớc đây trong phạm vi vông ty. - S•u tập dự liệu về các công ty t•ơng tự đã chấp nhận ph•ơng pháp phát triển mới. - S•u tập các báo cáo có dẫn t• liệu, văn bản và các chứng cớ khác thành văn (cần đề phòng quá lý thuyết). - Có đ•ợc hỗ trợ của các chuyên gia phát triển phần mềm khác hoặc ở trong phạm vi công ty hoặc ở ngoài. Mọi dữ liệu cấn đ•ợc nghiên cứu và các ghi chú đ•ợc chuẩn bị chứng minh nhu cầu của các ph•ơng pháp phát triển mới. Dòng cuối phải là việc vận dụng những qui tình mới, thiết thực phát triển phần mềm là vì lợi ích của công ty. Đã giành đ•ợc sự phê chuẩn cần thiết của quản lý cấp trên, những nhà quản lý dự án phần mềm có thể chuyển sang vận dụng các ph•ơng pháp mô tả trong các ch•ơng sau. B•ớc đầu trong việc tìm hiểu những vấn đề cơ bản trong việc phát triển phần mềm đ•ợc thảo luận ở ch•ơng 2. 1.5. Tóm tắt. Việc phát triển phần mềm có thể khống chế đ•ợc. Có những ph•ơng pháp, những kỹ thuật, những tiêu chuẩn và các công cụ khi đ•ợc vận dụng đúng thì chúng thúc đẩy việc phát triển thắng lợi dự án phần mềm với ba mục tiêu trứ danh trong trí óc để phát triển phần mềm. 1. Theo đúng lịch trình. 2. Trong phạm vi ngân sách. 3. Theo yêu cầu. 18
  19. Quản lý dự án phần mềm Thắng lợi hay thất bại của dự án không chỉ liên quan đến ba mục tiêu phát triển cơ bản đó nh•ng cũng cả đến kỳ vọng của khách hàng: một khách hàng có thể hài lòng với đầu ra của một dự án trong khi khách hàng khác lại có thể không. Do đấy, thành công của dự án đ•ợc xác định tối hậu ở sự hài lòng của khách hàng. Một trong những trở ngại mà các nhà quản lý dự án th•ờng phải khắc phục là thiếu hỗ trợ của quản lý cấp trên đối với những ph•ơng pháp phát triển hiện đại. Rõ ràng là nhiều ph•ơng pháp và kỹ thuật mô tả trong cuốn sách này, có hiệu lực chỉ khi chúng đ•ợc sử dụng. Mọi lập luận chống lại các ph•ơng pháp luận phát triển mới chí có thể bác bỏ sau khi có sự chuẩn bị đầy đủ. Thông tin về thành công và thất bại của phát triển phần mềm trong quá khứ trong phạm vi một công ty cần đ•ợc thu thập cùng với các minh chứng hỗ trợ khác bằng văn bản. Mọi dự liệu cần đ•ợc nghiên cứu và các chi chú cần đ•ợc chuẩn bị để chứng minh cho nhu cầu về ph•ơng pháp phát triển mới. Dòng cuối nên là việc ứng dụng các chu trình phát triển phần mềm hữu hiệu mới là vì lợi ích của công ty. 19
  20. Quản lý dự án phần mềm Ch•ơng hai Những vấn đề phát triển phần mềm Một chút phòng xa Tại một lớp học mới đầy về quản lý dự án phần mềm, một trong các học viên đã hỏi: “Chúng tôi có một số vấn đề chủ yếu trong một dự án mà tôi đang quản lý. Chúng tôi không có đ•ợc t• liệu có hệ thống hay có đ•ợc một kế hoạch phát triển nào và dự án đang trên đ•ờng v•ợt ngân sách và chậm hơn lịch trình. Vậy tôi phải vận dụng mọi ph•ơng pháp và kỹ thuật học ở đây ra sao nhằm làm cho dự án trở lại đúng lịch trình ?” Đây không phải là một tình huống không phổ biến ở đó, một ph•ơng thuốc thấn kỳ đã tìm cho một tình huống gần gây thảm họa. Những dự án quản lý tối có thể đi đến trì trệ và ngân sách v•ợt đến hai thậm chí ba trăm phần trăm và trong vài tr•ờng hợp lại có thể bị bãi bỏ. Hầu hết những ph•ơng pháp quản lý dự án hiện đại ban đầu bao giờ cũng quan tâm phòng xa (chứ không phải là hiệu chính) những vấn đề loại đó. Việc phòng ngừa những vấn đề thì dễ hơn và ít tốn kém hơn là giải quyết chúng. Những biện pháp phòng ngừa thiết thực hẳn là: - Định vị sớm vấn đề và những vấn đề tiềm ẩn. - Giải quyết vấn đề tr•ớc khi chúng tuột khỏi tầm tay. - Lập kế hoạch tr•ớc (đối phó) với những vấn đề tiểm ẩn. Những vấn đề sẽ trở nên tốn kém hơn giải quyết khi dự án tiến triển đến những giai đoạn phát triển cao hơn. Những vấn đề bị lãng quên cũng có thể lan truyền sang các lĩnh vực khác của dự án làm cho việc hiệu chính chúng trở nên khó khăn hơn. Do đấy việc thiết lập những qui trình để định vị sớm và hiệu chính các vấn đề là quan trọng. Ch•ơng này giải quyết nguyên nhân của một số thể loại rất thông th•ờng của vấn đề phát triển phần mềm và thảo luận tác động của chúng đến quá trình phát triển. Ch•ơng này cũng thảo luận việc dự kiến những vấn đề nhằm giảm thiểu tác động của chúng tới dự án. Các ch•ơng sau đề ra những ph•ơng pháp phòng ngừa các vấn đề mô tả ở đây khỏi xảy ra. 2.1. Những vấn đề cơ bản. Có rất nhiều vấn đề cơ bản mà nhà quản lý dự án hình nh• tìm thấy trong bất cứ dự án phầm mềm nào. Những vấn đề cơ bản đó gây ra bởi những tình huống sau đây bao giờ cũng có thể phòng tr•ớc sẽ phát sinh: - Yêu cầu ban đầu không đầy đủ. - Phụ thuộc ở các nguồn bên ngoài (các ng•ời bán hàng, các chủ thầu phụ v.v ) - Các khó khăn trong kết thúc dự án. - Thay thế th•ờng xuyên nhân sự thực hành phát triển (xáo trộn đội ngũ). 20
  21. Quản lý dự án phần mềm Các vấn đề cơ bản khác th•ờng nảy sinh do sai lầm quản lý thông th•ờng nh•: - Dự toán tồi. - Theo dõi và giám sát không đầy đủ. - Thay đổi không kiểm soát đ•ợc. Con đ•ờng tốt nhất để định vị một vấn đề sớm là đi tìm nó. Rõ ràng, đầu tiên là tìm xem vần đề th•ờng nảy sinh nhiều nhất ở đâu. Chẳng hạn thay đổi th•ờng xuyên và không kiểm tra đ•ợc với việc đặc tả các yêu cầu th•ờng hiển nhiên là nguồn chủ yếu của những vấn đề thiết kế. Những chủ thầu phụ và ng•ời bán hàng không giám sát đ•ợc là một trong những nguồn bất ngờ, thông th•ờng nhất đặc biệt là lúc họ báo cáo các vấn đề kỹ thuật và trì hoãn vào, chính những phút cuối cùng đối với các nhà quản lý dự án thì việc biết phải kiếm ở đâu do đó quan trọng nh• việc biết phải làm gì. 2.1.1. Những vấn đề liên quan đến các yêu cầu của dự án. Đặc tả các yêu cầu của dự án sẽ mô tả sản phẩm phải đ•ợc sản sinh ra bởi nhóm phát triển (coi ch•ơng 4). Nếu những yêu cầu không đ•ợc đặc tả đầy đủ thì chỉ các may mắn thuần túy mới đảm bảo đ•ợc là sản phẩm đáp ứng yêu cầu của khách hàng4. Sau đây là một số thí dụ các vấn đề liên quan đến đặc tả yêu cầu nghèo nàn. - Quên các đặc điểm. Khách hàng tin chắc là một số đặc điểm bị bỏ quên hẳn phải nằm trong sản phẩm căn cứ ở những thảo luận không chính thức (th•ờng với ng•ời không đúng). Ghi chép, bình luận và nhận xét ở các cuộc họp nh•ng không căn cứ ở đặc tả yêu cầu chính thức. - Có những đặc điểm không cần thiết đ•ợc đ•a vào. Đội ngũ phát triển đã tin chắc là khách hàng hẳn hết sức vui thích về những đặc điểm ngoại hạng đ•ợc thêm vào sản phẩm (th•ờng không hỏi ý kiến khách hàng). Một thí dụ hẳn là thêm sự truy nhập hệ thống bằng khẩu ngữ khi khách hàng lại muốn hệ thống sẵn sàng cho bất cứ ai. - Đặc điểm mà chúng hoạt động khác với điều mong đợi. Khách hàng giải thích không đầy đủ về mộ đặc điểm cần thiết và thế là đội ngũ phát triển hiểu cái yêu cầu đó theo cách hiểu của mình. Một thí dụ có thể là yêu cầu "cập nhật th•ờng xuyên cơ sở dữ liệu". Các nhà phát triển đã tạo ra một hệ thống cập nhật cơ sở dự liệu mỗi lần một ngày trong khi khách hàng muốn nói là một giờ mỗi lần. - Những đặc điểm cần thiết mà chẳng ai nghĩ đến. Khách hàng không cần thiết là một chuyên gia máy tính và do đó có thể không ý thức đ•ợc là một đặc điểm, đặc biệt nào đó phải cần đến. Thí dụ có thể là nhu cầu về bade up đầy đủ; khách hàng có thể cho là bade up là không cần thiết vì rằng nếu dịch vụ máy tính bị giám đoạn (thí dụ do 4 Từ khách hàng ở đây đ•ợc sử dụng theo nghĩa rất rộng bao gồm khách hàng chính thức, ban tiếp thị, nhóm ng•ời dùng, quản lý v.v 21
  22. Quản lý dự án phần mềm mất điện) thì việc mất một hay hai giao dịch l•u trữ trong bộ nhớ sẽ chẳng thành vấn đề. Thế nh•ng khách hàng có thể đã không xem xét sự việc là những điều khiển đĩa cũng có thể đổ vỡ và mất đi mọi dự liệu của họ. Rõ ràng là những yêu cầu đ•ợc đặc tả kém lại là vấn đề cho nhà phát triển nhiều cũng nh• cho khách hàng. Dù sao, nhà sản xuất th•ờng ở vị thế tốt hơn để biên soạn những yêu cầu hơn là khách hàng. Thông th•ờng đặc tả yêu cầu tốt nhất là kết quả của sự cố gắng phối hợp của cả nhà phát triển lần của khách hàng với văn bản thực đ•ợc soạn thành văn của nhà phát triển và đ•ợc chấp nhận bởi khách hàng. 2.1.2. Những thay đổi th•ờng xuyên. Thật cực kỳ hiếm khi tìm đ•ợc một dự án phần mềm qui hoạch tốt lại đi đến kết cục thắng lợi với đặc tả yêu cầu đ•ợc dán nhãn. Ph•ơng án 1.0. Thay đổi là không tránh khỏi suốt chu trình phát triển phần mềm. Dù sao, trong phần lớn tr•ờng hợp một thay đổi đ•ợc đ•a ra chậm thì thực hiện thay đổi lại càng tốn kém. Một số thay đổi thỏa đáng hẳn là phải quản lý đ•ợc. Khi dòng các thay đổi đổ vào nh• thác lũ thì chúng trở thành vấn đề. Ngay chỉ một thay đổi có thể thành vấn đề nếu nó đ•ợc yêu cầu ngay trong phát triển của dự án và nếu nó dẫn đến thay đổi chủ yếu về ph•ơng h•ớng. Những thay đổi quá mức tạo nên cái vẫn th•ờng đ•ợc coi là hội chứng mục tiêu di động. Nhà quản lý dự án không những thay đổi ph•ơng h•ớng và đội ngũ phát triển trở thanh vừa bối rối vừa mất mục tiêu. Thay đổi có thể phá vỡ dự án nếu chúng không đ•ợc ghi thành văn bản và giám sát đầy đủ. Những thay đổi với số l•ợng thỏa đáng, phải đ•ợc quản lý, vận dụng cơ chế kiểm tra sự thay đổi một cách có hệ thống. Ph•ơng pháp đó trong phạm vi tổ chức kiểm tra cấu hình, đ•ợc thảo luận ở ch•ơng 7. 2.1.3. Dự toán và các vấn đề liên quan. Dự toán tốt là quan trọng vì chúng tạo thành nền móng của kế hoạch phát triển dự án tốt. Kế hoạch đó, do nhà quản lý dự án chuẩn bị đ•ợc lập thành trong các giai đoạn ban đầu của dự án và bao gồm dự toán liên quan đến. - Ngân sách phát triển dự án - Lịch trình phát triển dự án - Tài nguyên phát triển cần đến (đội ngũ phát triển thiết bị phát triển v.v ) Những dự toán kỹ thuật cũng đ•ợd hình thành trong pha thiết kế và bao gồm: - Các đặc tính của phần mềm (dự toán về cỡ bộ nhớ, cơ sở dữ liệu v.v ). 22
  23. Quản lý dự án phần mềm - Các đặc tính của phần cứng về cỡ mục tiêu cần đến (dự toán tốc độ CPU, khả năng đầu vào, đầu ra; khả năng điều khiển đĩa v.v ). Dự toán là cơ sở cho nhiều quyết định kỹ thuật và quản lý dự toán tồi dẫn đến quyết định dở. Dự toán tồi có thể hiểu là quá cao hoặc là quá thấp và quyết định theo đó hoặc là tạo ra lãng phí hoặc thiếu tài nguyên phát triển. Điều này hình thành sai lầm trong qui hoạch, nh•: - Lịch trình quá ngắn hoặc cao thái quá. - Ngân sách quá thấp hay quá tăng giả tạo. - Quá thiếu hay quá thừa ng•ời làm và những sai lầm trong thiết kế kỹ thuật, nh•: - Những máy tính trong mục tiêu quá nhiều (và đắt hơn) hơn cần thiết hoặc không thể hỗ trợ ứng dụng đ•ợc phát triển. Những vấn đề nảy sinh từ dự toán thấp th•ờng gay cấn hơn là những vấn đề nảy sinh từ dự toán cao. Hiểu rõ điều này, các nhà dự toán th•ờng thêm vào một số yếu tố bất trắc (cho rằng đến 30%) trong dự toán của minh, giả định rằng quá cao còn hơn quá thấp. Dù sao dự toán cao có thể không gây ra thất bại của dự án nh•ng có thể ngăn cản dự án chẳng bao giờ đ•ợc khởi công. Đã có nhiều ph•ơng pháp đ•ợc phát triển nhằm tạo ra các loại dự toán khác nhau ở các giai đoạn khác nhau của dự án (coi các ch•ơng 9 và 10). Dù sao, ngay những dự toán chuẩn bị tốt có thể dẫn đến những vấn đề nếu chúng không đ•ợc cập nhật trên một cơ sở định kỳ và đều đặn. Rõ ràng là thông tin tốt hơn và đầy đủ hơn tạo nền dự toán tốt hơn. Do đó khi dự án tiến triển và có nhiều thông tin hơn, dự toán cần đ•ợc xem xét lại và hiệu chỉnh. Điều này dẫn đến việc giám định lại các quyết định phát triển, tạo cho các vấn đề tiềm ẩn đ•ợc đề cập sớm tr•ớc khi chúng trở thành gay cấn (coi phần 2.2 về phân tích rủi ro). 2.1.4. Nguồn lực bên ngoài. Các vấn đề phát triển dự án th•ờng dễ quản lý nhất khi mọi nhân tố phát triển đ•ợc điều khiển bởi quản lý dự án. Dù sao, điều này không phải bao giờ cũng có đ•ợc. Nhiều dự án phụ thuộc ở nhiều nguồn bên ngoài nh•: - Chủ thầu phụ - Ng•ời bán thiết bị - Những dự án phát triển song hành - Những ng•ời cung cấp dịch vụ (bảo trì, huấn luyện, lắp đặt v.v ) - Các chức năng hỗ trợ (thông tin điện thoại mạng, những cung cấp dự liệu. Dự phụ thuộc vào các nguồn bên ngoài hẳn phải đ•ợc phản ánh trống). Kế hoạch phát triển dự án. Điều này có nghĩa trong phạm vi các giao •ớc và dự toán nhận đ•ợc từ các nguồn khác. Theo thế, dự toán trong kế hoạch không thể tốt hơn dự toán nhận từ các nguồn khác. Việc trông cậy vào các nguồn bền ngoài có thể gây ra những vấn đề sau: 23
  24. Quản lý dự án phần mềm - Chậm trễ lịch trình, do việc giao chậm các thành phần dự án. - Sự kém cỏi quá chất l•ợng và thiết kế thiết bị phát triển và các thành phần dự án bên ngoài. - Thành phần bên ngoài không t•ơng hợp do vì sự sai lệch của nhà phát triển bên ngoài hay bán hàng với đặc điểm đã thỏa thuận hay đã công bố. - Hỗ trợ sản phẩm nghèo nàn đối với các thành phần bên ngoài. Do có ý thức đ•ợc những vấn đề tiềm ẩn đó, nhà quản lý dự án có thể đảm bảo rằng họ đ•ợc định vị thích hợp trong hợp đồng hay thỏa thuận với nguồn bên ngoài. Những vấn đề đó có thể đ•ợc ngăn ngừa nều đ•a vào trong hợp đồng những mức phát về chậm trễ trong giao hàng hay khuyết tật trong sản phẩm (coi các ch•ơng 3 và ch•ơng 9). Những đề phòng sớm có thể đ•ợc phát hiện khi th•ờng xuyên xét duyệt lại công việc đ•ợc phát triển bởi chủ thầu phụ và đòi hỏi sẽ báo cáo tiến độ th•ờng kỳ. 2.1.5. Kết thúc một dự án phần mềm. Nh• mọi nhà quản lý dự án đều biết, các dự án khó mà bắt đầu đ•ợc kinh nghiệm cho thấy là chúng th•ờng không ít khó khăn để đi đến kết thúc. Đi tới đoạn kết của dự án, luôn luôn các bên quan tâm khác nhau phát sinh những yêu cầu. Nh• phê phán những thay đổi mới và những hoạt động phút chót khác nữa. Điều này là đặc biệt có thực với những dự án giá cố định phát triển cho khách hàng theo hợp đồng (coi ch•ơng 3). Những vấn đề chính liên quan đến việc kết thúc dự án là: - Tranh chấp giữa khách hàng và nhà phát triển về việc lý giải và cung ứng mọi đặc điểm đ•ợc yêu cầu - ý đồ đ•a vào những thay đổi ở phút chót. - Thất bại của hệ thống và khuyết tật thiết kế xác định trong quá trình cài đặt và thử nghiệm hệ thống. - Khó khăn trong việc giữ cho đội ngũ phát triển hợp lực lại với nhau và năng động. Khi tình hình căn thẳng giảm đi vào gần cuối dự án có tình trạng sút giảm nhiệt tình t•ơng ứng trong những thành viên còn lại của đội phát triển. Trách nhiệm của nhà quản lý dự án là đảm bảo cho việc kết thúc dự án có trật tự và thắng lợi. Điều này đ•ợc thực hiện nhờ việc qui hoạch chi tiết lúc ban đầu dự án và quản lý dự án có hiệu quả xuyên suốt dự án. Đặc biệt, điều này đòi hỏi rằng: - Kế hoạch thử nghiệm thu phải đ•ợc chuẩn bị lập tài liệu và đ•ợc khách hàng phê chuẩn tr•ớc khi kêt thúc dự án. Mức độ nhân sự và sự phân công công việc phải đ•ợc lập lịch trình, có tính đến việc giảm dần trong qui mô đội ngũ phát triển vào cuối dự án. -Việc đ•a ấn phẩm ra thị tr•ờng phải đ•ợc lập kế hoạch tốt, kể cả đóng gói soạn thảo t• liệu, huấn luyện, cài đặt và chuyển tiếp có trật tự sang pha bảo trì và hỗ trợ. Sự kết thúc thắng lợi của dự án là bắt đầu của chu trình phát triển khác: Những đặc tả yêu cầu, những kế hoạch thử nghiệm hay những kế hoạch 24
  25. Quản lý dự án phần mềm phát triển nghèo nàn, tất cả đều dẫn đến những vấn đề chủ yếu lúc kết thúc dự án. 2.1.6. Tuyển dụng nhân viên và thuyên chuyển. Khó khăn trong việc tuyển dụng các thành viên đội ngũ phát triển là một trong những vấn đề đầu tiên mà ng•ời quản lý dự án phần mềm gặp phải. Tr•ớc khi bất cứ dự án nào đ•ợc tung ra, đội ngũ phát triển ban đầu phải đ•ợc thiết lập và các vấn đề này sẽ không kết thúc một khi đội ngũ tại vị. Giữ đ•ợc đội ngũ th•ờng khó nh• thiết lập nó. Frenkel (1985) báo cáo là nhu cầu kỹ s• phần mềm tăng theo hàm số mũ trong khi năng suất tăng theo mức khoảng 5% mỗi năm. Các tr•ờng đại học Hoa kỳ và châu Âu đang không cung cấp kỹ s• phần mềm đủ để bù đắp lỗ hổng giữa cung và cầu. Trên thực tế không những lỗ hổng không đ•ợc lấp kín mà lại đang rộng ra ở mức đáng lo ngại. Khối l•ợng thời gian bình quân mà một kỹ s• phần mềm ở lại nghề giảm khi yêu cầu kỹ s• tăng. Điều này không chỉ gây ra bởi sự thuyên chuyển của kỹ s• phần mềm giữa các công ty mà cơ sở sự thuyên chuyển trong phạm vi các công ti. Vì các công ty này đang tìm cách sử dụng hữu hiệu hơn các kỹ s• của mình. Sự thuyên chuyển trong phạm vi các công ty không chỉ do tình trạng thiếu kỹ s• phần mềm mà còn do chi phí về họ có thể vẫn ngăn trở thành việc tuyển bổ sung.5 Thuyên chuyển nhân sự bản thân nó là một vấn đề trọng yếu. Sự ổn định có của đội ngũ và do đó vào thắng lợi của dự án. Các vấn đề liên quan đến tuyển nhân sự và thuyên chuyển luôn bao gồm: - Việc đầu t• đáng kể đ•ợc đòi hỏi trong đ•ờng biểu diễn học tập và đào tạo thành viên đội ngũ phát triển mới. - Thuyên chuyển nhân sự luôn luôn sẽ giảm đi tinh thần đội ngũ và tác động không lợi đến động cơ đội ngũ. - Tuyển chọn th•ờng tốn kém và mất thì giờ nó đòi hỏi nhiều cuộc phỏng vấn và cả phí tuyển dụng. - Thuyên chuyển nhân sự luôn tạo ra tình trạng thiếu kiện định trong phát triển dự án. Trong các vấn đề phát triển phần mềm, những gì liên quan đến phát triển đội ngũ th•ờng đ•ợc nhận thức là gay cấn nhất. Các thành viên đội là nguồn phát triển quan trọng nhất cỡ chính họ đóng góp nhiều nhất cho sự thành công hay thất bại của dự án. 5 Kinh tế học cơ bản chỉ ra rằng khi có đ•ợc kỹ s• thì chi phí về họ sẽ giảm (căn cứ ở cung và cầu trong phạm vi thị tr•ờng nghề nghiệp. Dù sao, trong những năm gần đây, việc cung các kỹ s• phần mềm không bao giờ đủ lớn để tạo ra tác động đó ngoại trừ ở những khoảng thời gian ngắn ngủi tại các địa điểm cô lập). 25
  26. Quản lý dự án phần mềm 2.1.7. Theo dõi và giám sát. Theo dõi và giám sát là những nhiệm vụ quản lý. Khi các vấn đề phát sinh ở những lĩnh vực này và liên quan, chúng th•ờng là hậu quả của các qui trình quản lý dự án không thích hợp và không hiệu lực. Một trong những kết quả thông th•ờng nhất là nhà quản lý dự án không có ý thức về sự tồn tại của những vấn đề chủ yếu ở giai đoạn mà chúng có thể đ•ợc kiềm chế và hiệu chỉnh tốt nhất. Việc theo dõi và giám sát có hiệu quả đòi hỏi sự tiếp xúc trực tiếp giữa quản lý dự án và đội ngũ phát triển (coi ch•ơng 7). Một trong những nguyên nhân chủ yếu của các vấn đề theo dõi và giám sát là hội chứng tháp ngà nơi tồn tại kẽ nứt th•ờng trực giữa quản lý dự án và phần còn lại của đội ngũ phát triển. Điều này dẫn đến: - Luông thông tin không chính xác hay không có. Đóng góp đáng kể vào những quyết định quản lý tồi. - Phát triển không phối hợp: tình huống này th•ờng đ•ợc mô tả khi một đội ngũ phát triển đang triển khai hai dự án khác nhau. Điều này xảy ra khi các thành viên đội ngũ phát triển không phối hợp và không đ•ợc giám sát lại đã tiến hành theo những h•ớng khác nhau. - Trí tuệ lịch trình và bội chi ngân sách, điều này gây ra do dự toán tồi dựa vào các thông tin không đúng. Thông tin là thành phần cơ bản của bất cứ thể loại quản lý nào. Do đấy, giám sát tồi đi đối với luông thông tin không thích hợp là cốt lõi của quản lý dự án tồi. Cả ba vấn đề trên mô tả hậu quả chung của quản lý tồi. Danh mục các vấn đề kéo theo hẳn đúng là bao trùm hầu hết các kiểu vấn đề phát triển dự án. Các ph•ơng pháp tạo lập những kênh thông tin có hiệu lực và những qui trình báo cáo đ•ợc tổ chức tốt sẽ đ•ợc mô tả ở ch•ơng 5. 2.2. Phân tích rủi ro. Nhìn xa là phẩm chất quản lý tuyệt hảo th•ờng có thể đ•ợc phát triển theo kinh nghiệm. Thật vậy, trong nhiều tr•ờng hợp, các vấn đề có thể đoán tr•ớc. Trong những tr•ờng hợp đó, nhà quản lý có thể lập kế hoạch về khả năng mà vấn đề sẽ xảy ra khi dự tính khả năng của nó, đánh giá tác động của nó và chuẩn bị tr•ớc các giải pháp. Điều này th•ờng đ•ợc gọi là sự phân tích rủi ro và là một ph•ơng tiện hiệu quả để đấu tranh chống lại những vấn đề phát triển tiềm ẩn. Tiến hành phân tích rủi ro có nghĩa là đã đ•ợc dự bị sẵn sàng. Đây là một hình thức bảo hiểm, ý t•ởng cơ bản là nếu một vấn đề có nảy sinh thì một giải pháp đã có sẵn. Giống nh• mọi bảo hiểm, phân tích rủi ro th•ờng cũng phải trả giá. Chi phí dự phòng cho sự phát sinh một vấn đề tr•ớc hết là chi phí để có đ•ợc giải pháp đối phó sẵn trong tay, trong khi vấn đề có thể xảy ra, có thể không. Trong một số tr•ờng hợp, chi phí có thể là tối thiểu: Chỉ là thời gian cần để tiến hành phân tích và lập t• liệu cho giải pháp và thời gian để theo dõi vấn đề. Trong các tr•ờng hợp khác, chi phí có thể là lớn lao, chẳng 26
  27. Quản lý dự án phần mềm hạn, giá của một bộ phận thay thế của thiết bị phát triển. Trong mọi tr•ờng hợp, một vấn đề đã đ•ợc phân tích và giải quyết sớm hơn thì đơn giản hơn rất nhiều so với việc giải quyết vấn đề sau khi phát sinh bất ngờ. 2.2.1. Dự kiến những vấn đề cần giải quyết. Giai đoạn đầu tiên của phân tích rủi ro đòi hỏi duyệt xét mọi kế hoạch quản trị và kỹ thuật của dự án nhằm minh định các vấn đề tiềm ẩn nó bao gồm: - Kế hoạch phát triển dự án. - Đặc tả yêu cầu. - Đặc tả thiết kế. Bảng 2.1. Thí dụ về danh sách vấn đề dự liệu Vấn đề Mô tả 1. Chậm giao máy tính Nếu máy tính để phát triển không đ•ợc giao vào để phát triển 1/6 nh• kế hoạch, giai đoạn thích hợp sẽ bị chậm. 2. Bộ nhớ không đủ Cỡ của phân l•u trữ bộ nhớ của hệ thống có thể v•ợt 8 mêga baitơ (cỡ bộ nhớ tối đa đ•ợc vi tính cấp d•ỡng). 3. Không có chuyên gia Hệ thống đòi hỏi thay đổi cho hệ thống điều hệ thống điều hành hành chuẩn J.Adams là chuyên gia hệ điều hành duy nhất trong công ty và ông có thể bận không đ•ợc sử dụng cho hệ thống này. 4. Thời gian đáp ứng của Thời gian đáp ứng của hệ thống yêu cầu cho đầu hệ thống quá chậm vào có thể quá 5 giây so với đặc tả trong yêu cầu. 5. Thuyên chuyển nhân Lịch trình là xát xao với thời gian trống tối sự nhiều thiểu. Nếu có sự thay thể nhân sự quá mức bình quân trong phát triển chúng ta sẽ tr•ợt thêm lịch trình. 6. Truyền thông quá Góc truyền thông chuẩn quá chậm. Thiết kế dựa chậm trên gói truyền thông nhị phân mới. Góc này ch•a bao giờ đ•ợc sử dụng với hệ thống này và có thể không thích hợp. 7. Chậm giao và hệ Hệ thống phụ cơ sở dữ liệu đ•ợc hợp đồng phụ thống phụ cơ sở dữ liệu với tập đoàn phát triển phần mềm (SOI) cam kết giao hàng 15-4. SOI có thể không giao đúng thời hạn nên làm chậm sự thích hợp và pha thử nghiệm cuối. Mọi lệ thuộc chủ yếu trong kế hoạch phát triển dự án đều đ•ợc xem xét và đánh giá. Các thí dụ có thể là sự lệ thuộc ở nguồn bên ngoài nh• 27
  28. Quản lý dự án phần mềm chủ thầu phụ, ng•ời bán hàng, nhà cung cấp và các nhà làm dịch vụ. Các vấn đề sẽ nảy sinh nếu các hợp phần hay dịch vụ bên ngoài không đ•ợc cung cấp kịp thời hay không hoạt động nh• trông đợi. Đặc tả thiết kế dự án là một kế hoạch chi tiết về việc làm thế nào để các yêu cầu đ•ợc thực hiện. Các quyết định về sự thực hiện đ•ợc đòi hỏi có thể chứa các vấn đề tiềm năng. Chẳng hạn, các vấn đề sẽ nảy sinh ra nếu phần cứng đ•ợc lựa chọn lại hóa ra không thích hợp, chẳng hạn nh• CPU quá chậm, mạng cục bộ không đủ tin cây, hoặc bộ nhớ không đủ. Sau đó mọi vấn đề dự liệu đ•ợc tập hợp lên danh sách, mỗi vấn đề đ•ợc minh định và mô tả về tác động tiềm ẩn ảnh h•ởng tới dự án. Bảng 2.2. cho một thí dụ về danh sách vấn đề dự liệu. Danh sách vấn đề dự liệu nên đ•ợc tập hợp nhờ có sự tham gia của các thành viên chính của đội ngũ phát triển dự án. Những ng•ời khác có thể cũng đ•ợc mời đóng góp cho danh sách đó, căn cứ ỉw kinh nghiệm cùng kiến thức kỹ thuật hay quản trị của họ; Có thể bao gồm cả những ng•ời từ các đội ngũ dự án khác, các nhóm hỗ trợ phòng pháp chế hay phòng mua sắm (kinh doanh) của công ty. Trong khi mục tiêu không phải là liệt kế mọi vấn đề nhận thức đ•ợc mà mỗi dự án có thể kinh qua, cần thiết là minh định những vấn đề hẳn đ•ợc xem một cách hợp lý là có liên quan đến dự án. Trong mọi tình huống, giai đoạn phân tích sau đây đ•ợc nhằm để cách ly chỉ những vấn đề nào có thể tác động lớn lao đến dự án và có thể một cách hợp lý đ•ọc xem là hẳn sẽ xảy ra 2.2.2. Pha phân tích Việc phân tích danh sách những vấn đề dự liệu đòi hỏi đánh giá mỗi vấn đề nhằm: 1. Dự toán xác suất vấn đề sẽ xảy ra. 2. Dự toán sáo động của vấn đề tới dự án 3. Quy cho mức độ nghiêm trọng của vấn đề. Xác suất đó và tác động đó nếu đ•ợc dự toán bởi quá một ng•ời. Mọi hạng mục trong danh sách đ•ợc dự toán tốt nhất trong một cuộc họp duy nhất đánh giá vấn đề để đảm bảo tính t•ơng đối của mức độ nghiêm trọng, giữa các vấn đề không bị lệch lạc. Mục tiêu là tránh những tình huống khi việc chậm giao của bên cung cấp A đ•ợc một ng•ời dự toán là 0.8 và việc chậm giao của bên cung cấp B đ•ợc một ng•ời khác dự toán là 0.6 trong khi cả 2 nhà dự toán hẳn đồng ý là hai xác suất này là bằng nhau. Nếu hai ng•ời ở trong cùng 1 phòng trong cùng 1 lúc thì sự lệc lạc t•ơng đối đó giảm đi. Một cách đơn giản và hiệu quả để tính mức độ nghiêm trọng của mỗi vấn đề đ•ợc dự liệu là: 1. Gán một số kỹ vọng giữa 1 và 10 căn cứ ở xác suất là vấn đề sẽ xảy ra, với 10 biều xác suất cao, và 1 xác suất thấp nhất (thí dụ nhân xác suất với 10). 28
  29. Quản lý dự án phần mềm 2. Gán một số giữa 1 và 10 căn cứ ở tác động của vấn đề với dự án với 10 biểu thị tác động cao và 1 tác động thấp. 3. Nhân trị giá có đ•ợc ở b•ớc (1) với tự giá có đ•ợc ở b•ớc (2) để tính mức độ nghiêm trọng cho vấn đề. Bảng 2.2. giới thiệu một thí dụ về cách tính mức độ nghiêm trọng có sử dụng các vấn đề dự liệu mô tả ở bảng 2.1. Bảng 2.2. Thí dụ về cách tính mức độ nghiêm trọng. ST Vấn đề Kỳ Tác Nghiêm T vọng động trọng 1 Chậm giao máy tính để phát 6 5 30 triển 2 Bộ nhớ không đủ 4 2 8 3 Không có chuyên gia hệ điều 5 5 25 hành 4 Thời gian đáp ứng của hệ thống 5 3 15 quá chậm 5 Thuyên chuyển nhân sự cao 5 8 40 6 Truyền thông quá chậm 2 8 16 7 Chậm giao hệ thống phụ cơ sở 3 9 27 dữ liệu Sau khi mức độ nghiêm trọng đã đ•ợc tính cho mỗi vấn đề dữ liệu, danh sách đ•ợc phân loại theo dự nghiêm trọng của vấn đề trong đó vấn đề nghiêm trọng nhất đứng đầu danh sách. Sau đó có thể quyết định xem vấn đề nào có mức độ nghiêm trọng ít hơn một trị giá nào đó (thí dụ 10) sẽ không đ•ợc xem xét. Sau đây những vấn đề còn lại đ•ợc đánh giá và tiến trình hành động chi tiết, gọi là kế hoạch đối phó bất ngờ đ•ợc lựa chọn cho mỗi vấn đề. Rồi thông tin đ•a vào bảng đối phó bất ngờ. Với mỗi lần đ•a vào bảng, một thành viên của đội ngũ phát triển đ•ợc bố trí là ng•ời theo dõi để theo dõi vấn đề và báo động quản lý dự án khi kế hoạch đối phó bất ngờ cần đ•a vào hoạt động giai đoạn này đ•ợc trình diễn ở bảng 2.3. Phân tích rủi ro đ•ợc hoàn thiện đầu tiên càng sớm càng tốt trong dự án, nh•ng không đ•ợc chậm hơn lúc kết thúc pha yêu cầu (coi ch•ơng 4). Dù sao, phân tích rủi ro không phải là hoạt động một lần khi dự án tiến triển, những vấn đề bổ sung có thể đ•ợc dữ liệu và những vấn đề khác có thể cần đ•a ra khỏi danh sách vấn đề. Khi có đ•ợc thông tin mới, việc đánh giá mức độ nghiêm trọng hoặc xác suất hẳn phải đ•ợc cải tiến. Do đấy các bảng phân tích rủi ro nên đ•ợc duyệt xét và cập nhật định kỳ và ở bất cứ khi nào khi có một sự cố quan trọng xảy ra (thí dụ một chủ thầu phụ thông báo chậm trễ lịch trình hay một quyết định thiết kế chủ yếu thấy cần phải hiệu chỉnh). 29
  30. Quản lý dự án phần mềm Bảng 2.3. Thí dụ về bảng ngẫu nhiên Vấn đề Nghiêm Kế hoạch đối phó bất ngờ Ng•ời trọng theo dõi 5 Thuyên chuyển 40 Cho tiền th•ởng hoàn thành J.Smith nhân sự cao dự án thắng lợi. 1 Chậm giao máy 30 Yêu cầu làm ca đêm về hệ H.Brown tính để phát triển thống phát triển của dự án khác. 7 Chậm giao hệ 27 Thiết kế một mô phỏng hệ W.Alda thống phụ cơ sở thống phụ cơ sở dữ liệu dữ liệu dùng để tích hợp. 3 Không có chuyên 25 Bố trí chuyên gia hệ điều H.Brown gia hệ điều hành hành ngoài công ty và thuê làm t• vấn 6 Truyền thông quá 16 Hợp đồng với công ty đã H.Troy chậm phát triển gói truyền thông nhị phân thích nghi cho gói vói dự án này. 4 Thời gian đáp ứng 15 Cho vào điều khỏan thỏa Y.Krot của hệ thống quá thuận nâng cấp CPU trong chậm hợp đồng mua máy tính. 2 Bộ nhớ không đầy 8 (không xem xét) đủ 2.2.3. Thực hiện các kế hoạch đối phó bất ngờ. Các kế hoạch đối phó bất ngờ đ•ợc thực hiện ở một trong những tr•ờng hợp sau: 1. Vấn đề dữ liệu diễn ra hay sắp xảy đến đến nơi. 2. Kế hoạch đối phó bất ngờ đòi hỏi đ•ợc chuẩn bị tr•ớc. Nói chung, các kế hoạch đối phó bất ngờ có thể đ•ợc nhìn nhận theo nh• cái kế hoạch, hành động đ•ợc xếp vào ngăn kéo để phòng khi dùng đến sau này. Dù sao, trong vài tr•ờng hợp, kế hoạch đ•ợc thực hiện tr•ớc khi vấn đề dự liệu xảy ra nh• phát triển một bộ mô phỏng tr•ờng hợp việc giao một hợp phần quyết định bị chậm trễ. Sau đó, nếu họpw phần đ•ợc giao đúng hạn thì bộ mô phỏng đó có thể bị bỏ đi. Lấy thí dụ về quá trình hoàn chỉnh chúng ta thử xem xét một dự án truyền thông cần đến một máy tính trung tâm nối bằng mạng diện rộng với vài vị trí máy tính nhỏ, có hai vấn đề tiềm ẩn đ•ợc minh định. - Hai máy tính có kiến trúc khác nhau có thể diễn giải thể thức truyền thông đã thiết kế đ•ợc một cách (thí dụ trình tự của các từ hai byte có thể bị đảo ng•ợc - LSB MSB chứ không phải MSB LSB). 30
  31. Quản lý dự án phần mềm - Công ty điện thoại đ•ợc chọn có thể không có khả năng lắp đặt đ•ờng dây thử nghiệm đún ghẹn cho pha tích hợp. Bảng 2.4. Danh mục vấn đề dữ liệu Vấn đề Mô tả 1. thể thức truyền thông Hai máy tính có kiến trúc khác nhau có thể không t•ơng hợp. diễn giải thể thức truyền thông đã thiết kế là khác nhau. 2. Đ•ờng dây thử Công ty điện thoại đ•ợc chọn có thể không có nghiệm có chậm để tích khă năng lắp đặt đ•ờng dây thử nghiệm đúng hợp. hạn để tích hợp. Bảng 2.5. Đo mức độ nghiêm trọng Vấn đề Kỳ Tác Độ nghiêm vọng động trọng 1. Thể thức truyền thông không 5 8 40 t•ơng hợp 2. Đ•ờng dây thử nghiệm có chậm 8 6 48 để tích hợp. Bảng 2.6. Bảng đối phó bất ngờ Vấn đề Độ Kế hoạch đối phó Ng•ời nghiêm bất ngờ theo dõi trọng 1. Đ•ờng dây thử 48 Đặt hàng đ•ờng dây Will Doo nghiệm có chậm để tích từ 2 công ty điện hợp. thoại phụ 2. Thể thức truyền thông 40 Sử dụng gói thông tin I.Hope không t•ơng hợp. ASCII Các bảng 2.4; 2.5 và 2.6 là các bảng phân tích rủi ro cho dự án truyền thông đó. Nừu khả năng có đ•ợc đ•ờng dây truyền thông bị chậm lại, điều này sẽ gây ít tác hại cho dự án hơn là vấn đề thể thức không t•ơng hợp. Việc theo dõi vấn đề này đã đ•ợc giao cho Wieliam Joo.Trách nhiệm của ông là đảm bảo những đ•ờng dây này đ•ợc đặt hàng từ hai công ty điện thoại khác (chỉ cho pha tích hợp thôi). Nếu công ty điện thoại có •u tiên thế sẵn sàng đúng hẹn thì những đơn đặt hàng từ hai công ty khác đ•ợc hủy và khả năng phí hủy bỏ phải trả. Một kỹ s• khác Jndira Hepe chịu trách nhiệm về theo dõi vấn đề thể thức truyền thông không t•ơng hợp. Chị ta phải đảm bảo gòi truyền thông 31
  32. Quản lý dự án phần mềm A.SCII đơn đ•ợc đặt cho cả hai máy tính phí về gói áCII sẽ là lãng phí nếu thể thức nhị phân đ•ợc chọn sẽ hoạt đồng. Giải phóng áCII thay thế hầu nh• chắc chắn chậm hơn nhiều, nh•ng nó sẽ cung cấp giải pháp tạm thời cho đến khi vấn đề không t•ơng hợp đ•ợc giải quyết. 2.3. Tóm tắt Các ph•ơng pháp quản lý dự án hiện đại lúc đầu quan tâm đến việc các vấn đề phát triển dự án (việc phòng ngừa không hiệu chỉnh). Phòng ngừa các vấn đề thì dễ hơn và ít tốn kém hơn là giải quyết chúng, những biện pháp phòng ngừa có hiệu quả nêu là: - Định vị các vấn đề và các vấn đề tiềm ẩn sớm. - Giải quyết vấn đề tr•ớc khi tuột khỏi tầm tay. - Lập kế hoạch tr•ớc cho những vấn đề tiềm ẩn Có rất nhiều vấn đề cơ bản chung cho hầu hết các dự án phầm mềm. Phần lớn những vấn đề đó dẫn xuất từ: - Xác định yêu cầu không đầy đủ. - Thay đổi luôn - Dự toán tồi - Tùy thuộc ở nguồn bên ngoài (ng•ời bán, chủ thầu phụ v.v ) - Khó khăn trong kết thúc dự án. - Luôn luôn thay thế nhân sự phát triển (thuyên chuyển nhân sự) - Theo dõi và giám sát không đầy đủ. Cách tốt nhát để định vị một vấn đề là sớm đi tìm kiếm nó. Rõ ràng, tr•ớc hết là tìm xem ở đâu vấn đề hay diễn ra nhất. Chẳng hạn những thay đổi đặc tả yêu cầu luôn luôn và không kiểm tra là không thuận lợi đ•ợc coi nh• nguồn gốc chủ yếu của những vấn đề thiết kế. Những chủ thầu phụ và ng•ời bán không giám sát đ•ợc là một trong hầu hết những nguồn gốc bất ngờ, những vấn đề kỹ thuật l•u lại và chậm chễ vào phút chót. Với nhà quản lý dự án thì biết đ•ợc ở đây phải tìm là quan trọng nh• biết đ•ợc phải làm gì. Biết phải làm gì bao gồm cả việc chuẩn bị tr•ớc sự xuất hiện của vấn đề. Trong nhiều tr•ờng hợp, các vấn đề có thể đ•ợc dự liệu. Nhà quản lý dự án có thể lập kế hoạch về khả năng vấn đề sẽ xảy ra bằng cách dự tính xác suất của nó, •ớc l•ợng tác động của nó và chuẩn bị giải pháp thay thế. Cái đó đ•ợc gọi là phân tích rủi ro và là biện pháp có hiệu quả trong việc đấu tranh với những vấn đề phát triển tiềm ẩn. Tiến hành phân tích rủi ro có nghĩa là chuẩn bị tr•ớc. Đây là một hình thức bảo hiểm mà ý t•ởng cơ bản là nếu một vấn đề xảy ra, giải pháp đã sẵn sàng. Giống nh• mọi bảo hiểm, phân tích rủi ro th•ờng phải trả giá. Chi phí chuẩn bị cho việc một vấn đề xảy ra tr•ớc hết là chi phí để có giải pháp gồm thay thế có sẵn trong tay. Trong một số tr•ờng hợp, chi phí có thể chỉ là tối thiểu: thời gian cần để phân tích và lập tài liệu cho giải pháp và thời gian theo dõi vấn đề. Trong các tr•ờng hợp khác, chi phí có thể lớn đáng kể: giá của một bộ phận thay thế của thiết bị phát triển. Trong 32
  33. Quản lý dự án phần mềm mọi tr•ờng hợp vấn đề đã đ•ợc phân tích giải quyết tr•ớc lại đơn giản hơn là giải quyết vấn đề đã xảy ra bất ngờ. Bài tập 1. Một công ty dịch vụ truyền hình cáp đang chuẩn bị thiết lập dịch vụ trong thời gian 8 tháng. Công ty cung cấp dịch vụ cho các khách hàng với phí cố định hàng tháng tùy thuộc ở qui mô dịch vụ mà họ yêu cầu. Công ty cũng cho chiếu những phim mới mỗi phim có thể cho một khách hàng xem theo yêu cầu qua điện thoại với công ty. Giờ công ty đang trong quá trình đặt mua thiết bị, mua các ph•ơng tiện và ký với khách hàng. Một công ty phần mềm đã hợp đồng phát triển một hệ thống làm hóa đơn cho các khách hàng. Hệ thống này sẽ giao diện với thiết bị để nhận thông tin về các buổi chiếu phim mói trên màn ảnh và sẽ giao diện với cơ sở dữ liệu của khách hàng để thông tin đều đặn về hóa đơn hàng tháng. Bạn hãy chuẩn bị một danh mục m•ời vấn đề gay cấn nhất mà bạn chi liệu trong phát triển dự án làm hóa đơn. Hãy thỏa thuận lý do của việc chọn lựa vấn đề của bạn. 2. Bạn hãu tính mức độ nghiêm trọng cho mỗi một vấn đề tiềm ẩn mà bạn đã định ở bài tập 1. Hãy giải thích việc phân định của bạn về tác động của dự án và các trị giá xác suất. Hãy gợi ý một ph•ơng pháp thay thế phân định mức độ nghiêm trọng cho những vấn đề dự liệu mà nó cũng tính cả chi phí chuẩn bị các kế hoạch đối phó bất ngờ. 3. Bạn hãy gợi ý những kế hoạch đối phó bất ngờ cho những vấn đề dự liệu mà bạn đã định ở bài tập 1. Hãy xét hai kế hoạch thay thế khác nhau cho mỗi một vấn đề. Xét chi phí của mỗi kế hoạch thay thế và sau đó chọn kế hoạch tốt nhất dựa trên ph•ơng pháp thay thể để phân định mức độ nghiêm trọng mà bạn gợi ý ở bài tập 2. Hãy chuẩn bị một bảng đối phó bất ngờ có chứa các kế hoạch đối phó bất ngờ mà bạn đã chọn. 4. Bài tập ở lớp: Chia lớp thành các nhóm 3 hay 4 sinh viên. Giao các bài tập 1, 2, 3 cho mỗi hóm. Yêu cầu mỗi nhóm trình bày phân tích rủi ro của mình cho số nhóm còn lại trong lớp. Thảo luận : a) Các danh mục vấn đề dự liệu khác nhau. b) Các kế hoạch ngẫu nhiên khác nhau. c) Các ph•ơng pháp khác nhau để phân định mức độ nghiêm trọng (liệu có 2 nhóm nào đã gợi ý ph•ơng pháp t•ơng tự ?) 33
  34. Quản lý dự án phần mềm Ch•ơng ba Phát triển phần mềm theo hợp đồng Mối quan hệ khách hàng - nhà phát triển Do những thay đổi nhanh chóng trong công nghệ trong vài thập niên gần đây, các tổ chức công nghệ cao ngày càng thấy cần thiết phải chuyển hóa trong các lĩnh vực đặc chủng, xác định rõ việc chuyển hóa không chỉ xác định nhiều nhánh mới của công trình học mà còn xác định những lĩnh vực chuyên môn trong phạm vi các bộ môn công trình học. Điều này đặc biệt đúng với công trình phần mềm. Thông th•ờng, các tổ chức không chuyên hóa trong phát triển phần mềm lại thuê các tổ chức khác phát triển phần mềm cho họ. Ngay cả những tổ chức có phát triển phần mềm của chính mình có thể quyết định thuê các chuyên gia bên ngoài ở những lĩnh vực đặc chủng. IBM đã thuê Mirosoft phát triển hệ điều hành PC DOS, vì Microft đã có kinh nghiệm trong phát triển các hệ thống vi tính còn IBM thì không. Ch•ơng này đề cập đến mối quan hệ giữa khách hàng và nhà phát triển phần mềm và cung cấp một số h•ớng dẫn làm sao tránh những cái bẫy cổ điển do những lợi ích mẫu thuẫn nhau. Mổc dù nhiều những vấn đề đó là chung cho mọi quan hệ khách hàng, nhà phát triển một số vấn đề tranh cãi là đặc biệt cho phát triển phần mềm. Việc phát triển phần mềm là rất ít xác định hơn và nhiều rủi ro hơn các lĩnh vực khác của công nghệ. Điều này th•ờng dẫn đến những hiểu lầm và bất đồng đáng ra đã có thể tránh đ•ợc nếu đ•ợc dự liệu và kiềm chế đủ sớm. Để tiêu chuẩn hóa thuật ngữ của chúng ta, tổ chức mà đề nghị đ•ợc đệ trình sẽ đ•ợc coi là khách hàng và tổ chức đệ trình đề nghị sẽ đ•ợc coi là ng•ời đề nghị. Các từ khác th•ờng đ•ợc sử dụng ở nơi khác cho ng•ời đề nghị bao gồm ng•ời đấu thầu, ng•ời bán hàng hay chủ thầu và cho khách hàng là ng•ời yêu cầu hay ng•ời đề xuất yêu cầu. Tổ chức đ•a ra đề nghị đ•ợc thẳng thầu sau khi lựa chọn, sẽ đ•ợc coi là nhà phát triển. 3.1. Chi phí cộng thêm đối lại với giá cố định. Th•ờng vẫn có mâu thuẫn về quyền lợi thực sự hay t•ởng t•ợng giữa khách hàng với ng•ời phát triển. Khách hàng thì muốn chi phí ít hơn và ng•ời phát triển lại muốn thu nhập nhiều hơn. Nh• chúng ta sẽ thấy mối quan hệ tốt giữa ng•ời phát triển và khách hàng không cần thiết phải dẫn đến tranh chấp về quyền lợi nh• thế. Cơ bản có 2 loại quan hệ theo hợp đồng giữa khách hàng và ng•ời sản xuất. 1. Chi phí cộng thêm (cũng gọi là chi phí theo thời gian và vật liệu) 34
  35. Quản lý dự án phần mềm 2. Giá cố định Hầu hết các quan hệ khác là một hình thức phối hợp nào đó giữa hai loại đó. 3.1.1. Hợp đồng phí cộng thêm Phí cộng thêm là mối quan hệ theo hợp đồng theo đó ng•ời phát triển đ•ợc trả cho chi phí dịch vụ đã làm và thêm vào đấy đ•ợc phép h•ởng mức lời thỏa thuận. Điều này thực ra giống nh• cho thuê ô tô: khách hàng trả cho số thời gian xe đ•ợc sử dụng (theo giờ, ngày, tuần v.v ) và cho mọi chi phí khác nh• bảo hiểm và xăng. Theo thế trong một hợp đồng phí cộng thêm, tổng phí của một dự án chỉ đ•ợc biết sau khi dự án đã hoàn thành. Lấy thí dụ, công ty Alpha có thể hợp đồng với công ty phần mềm Bêta để phát triển một hệ thống. Công ty Bêta sẽ đ•ợc công ty Alpha trả cho 180 cho mỗi giờ các kỹ s• của minh đầu t• cho dự án một khoản 20% bổ sung có thể đ•ợc thêm vào để bù đắp dịch vụ quản lý th• ký hay văn phòng khác. Các chi phí phụ phát sinh bởi công ty Bêta vì lợi ích của dự án sau đó đ•ợc công ty Alpha bồi hoàn các chi phí đó có thể bù đắp các lĩnh vực nh•: - Thiết bị phát triển của mục đích đặc tr•ng (máy tính, các bộ dịch, các mạng v.v ) - Chi phí đi lại phát sinh bởi nhân viên công ty Bêta vì lợi ích của dự án. - Thiết bị mục tiêu do công ty Bêta cung cáp cho công ty Alpha sử dụng. - Dịch vụ từ các nguồn bên ngoài khác do công ty Bêta yêu cầu cho dự án. Khách hàng (Công ty Alpha) có thể yêu cầu ng•ời phát triển (Công ty Bêta) phải đ•ợc phép tr•ớc về mọi chi phí đơn lẻ phát sinh v•ợt quá $250 và mọi chi phí v•ợt quá $600 tổng số hàng tháng. Mọi việc cho phép nh• thế luôn phải bằng văn bản. Điều này xác định quan hệ hợp đồng cơ bản về phí cộng thêm giữa hai công ty. Trong nhiều tr•ờng hợp, hợp đồng phí cộng thêm là tốt nhất có việc phát triển. Tuy nhiên, cũng có vô khối các vấn đề tiềm tàng. Một mâu thuẫn về quyền lợi có thể xảy ra do ng•ời phát triển động cơ hoàn thành dự án nhanh, hoặc do khách hàng miễn c•ỡng cho phép các chi phí phụ thêm. Phí cộng thêm th•ờng thích hợp cho những dự án nhỏ không xác định khi có khó khăn trong việc nhận biết tr•ớc các yêu cầu của dự án. Trên thực tể trong nhiều tr•ờng hợp pha yêu cầu dự án đ•ợc chào hàng nh• hợp đồng phí cộng thêm và các pha còn lại đ•ợc hợp đồng theo kiểu giá cố định, giai đoạn yêu cầu đ•ợc sử dụng để đ•a các phần còn lại của dự án đến trạng thái đủ xác định tốt mà nhờ nó có thể đ•ợc hợp đồng theo kiểu gia cố định đôi khi một công ty 35
  36. Quản lý dự án phần mềm đ•ợc ban cho hợp đồng phí cộng thêm cho giai đoạn yêu cầu về công ty khác đ•ợc ban cho các hợp đồng giá cố định với giai đoạn còn lại. Phí cộng thêm có thể đ•ợc chuộng ở khác hàng muốn nắm quyền kiểm soát quá trình phát triển. Trong một số tr•ờng hợp, ng•ời sản xuất đ•ợc coi nh• phần mở rộng của tổ chức của khách hàng và các hoạt động phát triển do khách hàng quản lý. Hợp đồng phí cộng thêm phải bao gồm các điều sau: - Danh sách những ng•ời đ•ợc giao làm dự án - Xác định công việc - Tỷ lệ phần trăm giao việc cho mỗi ng•ời - Mức công việc hàng giờ hay hàng ngày cho mỗi ng•ời - Tổng phí hành chính - Chi phí đ•ợc phép để đ•ợc bồi hoàn - Thủ tục làm hóa đơn - Thủ tục thanh toán - Thủ tục kết thúc Phần trăm giao việc liên quan đến số thời gian mà mỗi ng•ời sẽ giành cho dự án. Nó có thể là 100% cho một số kỹ s•, và 50-60% cho các chuyên gia trong các lĩnh vực đặc biệt. Tỷ lệ phần trăm giao việc cũng có thể đ•ợc tính hiểu theo tối đa hay tối thiểu, có nghĩa, chẳng hạn, một kỹ s• bảo hành chất l•ợng sẽ giành không quá 20 giờ mỗi tuần cho dự án và không ít hơn 10 giờ mỗi tuần cho dự án. Giá suất lập phiếu có thể là giá suất cố định cho mọi ng•ời đ•ợc giao việc của dự án hay mức cá nhân có thể đ•ợc đặt cho từng lớp ng•ời. Chẳng hạn với mỗi giờ làm việc cho dự án, ng•ời sản xuất sẽ lập phiếu thanh toán $80, bất kể ai làm việc cho giờ đó. Hay hợp đồng có thể qui định là kỹ s• thiết kế đ•ợc lập phiếu thanh toán $120 một giờ, ng•ời lập mã $60 một giờ, ng•ời viết t• liệu $50 một giờ và cứ tiếp tục. Ph•ơng pháp giá suất lập phiếu hợp đồng phí cộng thêm hầu nh• khó nhất là ph•ơng pháp lập phiếu thanh toán cá nhân theo Franh Jones đ•ợc lập phiếu thanh toán $90 một giờ John Shith $75 v.v Điều này có nghĩa mỗi khi một ng•ời đ•ợc thay thế hay bổ sung cho dự án thì giá suất theo giờ lại phải th•ơng thảo lại. Đối với một tổ chức phát triển phần mềm, có thể có những thuận lợi thiết thực trong các hợp đồng phí cộng thêm bao gồm: - Không có rủi ro tài chính hay kinh doanh - Thu thập biến thức và kinh nghiệm dựa vào một tổ chức khác. Dù sao, nh• trong phần lớn tr•ờng hợp, những thuận lợi đó lại đi đối với một số bật lợi bao gồm: - Lợi tức kihnh doanh thập - Có thể có sự bất bình trong nhân sự - Kiểm tra nhân sự và công việc phát triển - Bất đồng tiềm ẩn với khách hàng do thiếu các bị giảm đi, mục đích đ•ợc xác định rõ và nhân tố thúc đẩy. - Tính kế tục của hợp đồng không bảo đảm 36
  37. Quản lý dự án phần mềm Hầu hết nhân viên chuộng có đ•ợc xác định rõ ràng về tôn ti mà họ tùy thuộc. Trong hợp đồng phí cộng thêm, nhân viên làm việc trong phạm vi tôn ti của khách hàng nh•ng lại thuộc về tôn ti của ng•ời phát triển và điều này có thể gây ra bất mãn. Nói chung, theo quan điểm của ng•ời phát triển, hợp đồng phí cộng thêm là mối quan hệ kinh doanh vững chãi, lợi tức thấp, không rủi ro. Theo quan điểm của khách hàng thuận lợi của hợp đồng phí cộng thêm là: - Duy trì sự khống chế phát triển - Không cần cam kết cho toàn bộ hợp đồng dự án - Rủi ro kinh doanh có thể giảm đ•ợc (do khả năng kết thúc hợp đồng bất cứ lúc nào) Bất lợi có thể có của khách hàng là: - Chi phí phát triển gia tăng - Khách hàng phải đảm nhận rủi ro trong phát triển - Tham gia nhiều hơn trong phát triển - Bất đồng tiềm ẩn với ng•ời do thiếu mục đích xác định rõ và nhân tố thúc đẩy. Với khách hàng, khó xác nhận sự hấp dẫn của hợp đồng phí cộng thêm. Rõ ràng điều này thùy thuộc ở loại dự án và điều kiện để dự án phát triển cũng nh• ở nhận định kinh doanh không kỹ thuật khác. 3.1.2. Hợp đồng giá cố định Hợp đồng giá cố định là một cam kết của ng•ời phát triển sẽ cung cấp sản phẩm hay dịch dụ thỏa thuận với phí thỏa thuận trong phạm vi lịch trình thỏa thuận. Điều này t•ơng tự với mua tíc kê xe buýt theo đó công đi xe buýt thỏa thuận đ•a khách hàng đến nơi nhất định trong phạm vi thời gian biểu đã công bố với phí thỏa thuận. Tờt nhiên, du khách có thể chọn thuê xe chứ không mua tic kê xe buýt và rồi tự mình lái đến nơi của mình. Dù sao, điều này có thể trở nên tốn kém hơn và đòi hỏi ở ng•ời du khách đôi chút kỹ năng và kiến thức tr•ớc nh• kỹ năng lái xe và kiến thức về hành trình đến nơi. Nừu du khách (hay khách hàng) phải quyết định giữa việc tự mình tạo ra dịch vụ và việc hợp đồng với ai đó để cung cấp dịch vụ. Hợp đồng giá cố định chỉ có thể đ•ợc vận dụng cho một dự án xác định rõ. Cả khách hàng và ng•ời sản xuất phải có khả năng xác định sản phẩm hay dịch vụ cuối cùng mong muốn. Một khi điều này để thực hiện đ•ợc, một trong những yếu kém chính của hợp đồng cố định sẽ đ•ợc khắc phục. Lợi ích của hợp đồng giá cố định cho ng•ời phát triển là: - Khống chế đầy đủ quá trình phát triển - Lợi ích kinh doanh có thể cao hơn - Cam kết cho dự án trọn vẹn 37
  38. Quản lý dự án phần mềm - Cam kết cho dự án trọn vẹn là •u việt đáng kể so với hợp đồng phí cộng thêm ở đó nó có thể kết thúc bất cứ lúc nào tùy sự xét đoán của khách hàng. Tất nhiên, hợp đồng giá cố định cũng có một số bất lợi cho ng•ời phát triển, bao gồm: - Đảm nhận rủi ro kinh doanh và phát triển - Bất đồng tiềm ẩn với khách hàng do: + thay đổi yêu cầu liên tiếp + tiêu chuẩn hoàn thành dự án + giải thích yêu cầu Một tổ chức phần mềm thắng lợi sẽ th•ờng chuộng hợp đồng giá cố định. Đó th•ờng là những dự án tạo dựng danh tiếng chuyên môn của công ty và phát sinh lợi tức đảm bảo tăng tr•ởng. Bất hạnh là những dự án này cũng gây ra lỗ và th•ờng tác hại nghiêm trọng cho công ty cạnh tranh gay gắt để có hợp đồng quan trọng đôi khi làm cho công ty nhận thầu giá thấp cuối cùng gây ra lỗ cho ng•ời phát triển. Hầu nh• không thể tránh khỏi trong bất kỳ dự án nào ng•ời phát triển đ•ợc đòi hỏi thay đổi yêu cầu trong quá trình phát triển. Những thay đổi nh• thế th•ờng đi liền với chi phí bổ sung đòi khánh hàng và bao giờ cũng là nguyên nhân bất đồng giữa ng•ời sản xuất và khách hàng. Điều này th•ờng là do yêu cầu không rõ hay mơ hồ và nó lại dẫn đến bất đồng về chỉ tiêu trong việc hoàn thành dự án. Về cơ bản, điều này làm cho hợp đồng trở lại trạng thái không đ•ợc xác định đầy đủ. Theo quan điểm của khách hàng, •u việt của hợp đồng giá cố định bao gồm: - Ngân sách cố định cho dự án - Hầu hết các rủi ro phát triển đ•ợc chuyển sang ng•ời phát triển + tham gia tối thiểu trong quá trình phát triển Bất lợi cho khách hàng là: - Rủi ro chậm giao sản phẩm - Giảm sự khống chế quá trình phát triển - Bất đồng tiềm ẩn với ng•ời sản xuất do: + chi phí cao về thay đổi yêu cầu + chỉ tiêu hoàn thành dự án không rõ ràng - giải thích yêu cầu Ngay dù quyền lợi của ng•ời sản xuất và khách hàng có thể khác nhau, với hợp đồng giá cố định vẫn th•ờng đ•ợc cả hai bên •a chuộng. Nừu dự án là chi tiết đủ mức và rõ ràng và nếu quan hệ giữa hai bên đ•ợc xác định rõ thì các hợp đồng giá cố định có thể có lợi cho cả ng•ời phát triển lẫn khách hàng. 3.2. Các mối quan hệ khác giữa khách hàng - nhà phát triển. 38
  39. Quản lý dự án phần mềm Phí cộng thêm và giá cố định là hai trong số mối quan hệ theo hợp đồng cổ truyền giữa ng•ời phát triển và khách hàng. Có nhiều biến thức của hai mối quan hệ cơ bản đó kể cả các ghép nối phù hợp với các dự án đặc tr•ng. Một số trong những quan hệ đó liên kết với vai trò của khách hàng và ng•ời phát triển nhằm tạo nhiều yếu tố kích thích hơn cho ng•ời phát triển hỗ trợ mục tiêu của khách hàng ngoài những tránh nhiệm theo hợp đồng. Những loại khác của quan hệ khách hàng - ng•ời phát triển bao gồm: - Phối hợp giá cố định và phí cộng thêm - Liên doanh - Thỏa thuận bản quyền - Cam kết lâu dài ở phần 3.1. chúng ta đã xem xét một thí dụ về dự án phối hợp phí cộng thêm và giá cố định trong đó phần các yêu cầu đ•ợc phát triển theo phí cộng thêm và các phần còn lại của dự án phát triển theo gía cố định. Liên doanh là những tr•ờng hợp mà ranh giới giữa khách hàng và ng•ời phát triển có thể trở nên mờ ảo và phiền những thuận lợi và bất lợi thảo luận tr•ớc đây có thể không vận dụng đ•ợc. Có nhiều tr•ờng hợp mà một số hình thức liên doanh có thể là mong muốn cho hai bên nh• khi ng•ời phát triển muốn duy trì quyền về sản phẩm, hay khi ng•ời phát triển chung sức với khách hàng tài trợ một phần của cố gắng phát triển. Có một cách mà khách hàng có thể chào ng•ời phát triển tham gia vừa phải vào mặt kinh doanh của dự án là bằng cách thay thế bản quyền coi nh• thanh toán một phần. Điều này tạo nên qui mô bổ sung cho lợi ích của ng•ời phát triển trong thành công của dự án. Bản quyền thông th•ờng là ở chỗ thất bại của dự án có thể tạo nên ít lợi nhuận cho ng•ời phát triển hơn là một hợp đồng giá cố định thẳng thừng và thắng lợi của dự án sẽ làm tăng lợi nhuận của ng•ời phát triển. Mối quan hệ lâu dài th•ờng là quan trọng cho ng•ời phát triển. Trong nhiều tr•ờng hợp, những cam kết dài hạn cũng nằm trong lợi ích của khách hàng. Điều này xảy ra khi ng•ời phát triển do gắn bó ở hợp đồng ban đầu, giành đ•ợc lợi thế chủ yếu, qua kiến thức thu l•ợm, đối với những ng•ời khác cho công việc phát triển tiếp sau. Rõ ràng khi ng•ời phát triển hoàn thành thắng lợi một dự án lớn và phức tạp, anh ta có đ•ợc một lợi thế đáng kể so với các công ty khác về các tăng c•ờng trong t•ơng lai của dự án đó. Cam kết lâu dài theo đó có thể có lợi ích t•ơng hỗ cho cả hai bên trong đó khách hàng đảm bảo các dịch vụ sau này của ng•ời phát triển và ng•ời sản xuất đảm bảo cam kết thu nhập lâu dài. 3.3. Yêu cầu đối với một đề xuất (RFP). Phát triển phần mềm theo hợp đồng bắt đầu từ việc khách hàng lựa chọn ng•ời phát triển phần mềm. Yêu cầu về đề nghị hay RFT (ở Anh cũng gọi là mời thầu) là b•ớc đầu của quá trình lựa chọn. Để hiểu xem 39
  40. Quản lý dự án phần mềm RFP cần đ•ợc chuẩn bị thế nào, tr•ớc hết chúng ta hãy duyệt lại các b•ớc dẫn tới một quyết định đ•a ra yêu cầu về đề nghị. Trong ph•ơng pháp tiếp cận theo pha để phát triển phần mềm, thì pha tiềm dự án th•ờng đ•ợc xem là pha thai nghén. Đây là giai đoạn mà ý t•ởng đằng sau dự án kết tinh và hình thành dự án. Đây cũng là giai đoạn mà tổ chức quyết định xem dự án có thể đ•ợc phát triển nội bộ hay sẽ phải hợp đồng với một công ty khác. Các RFP không chỉ đ•ợc phát ra cho các dự án hoàn chỉnh; chúng cũng có thể đ•ợc phát ra để bảo d•ỡng phần mềm của một hệ thống hiện có hay cho riêng một pha đơn lẻ của dự án. Mọi RFP chuẩn bị kỹ phải có cũng thông tin cơ bản; các RFP không hoàn chỉnh cho kết quả là các đề nghị không hoàn chỉnh. 3.3.1. Một số vấn đề cơ bản. Tr•ớc khi thuê các dịch vụ phát triển của một tổ chức khác, một số vấn đề cơ bản cần đ•ợc xem xét tới: - Các mục tiêu của dự án là gì ? - Các tổ chức nào là gì đ•ợc xem xét cho công việc đó ? - Loại hợp đồng nào sẽ đ•ợc chào (giá cố định, phí cộng thêm v.v ) - Phải nhận đ•ợc các đáp ứng nào từ các nhà phát triển sao cho đáp ứng đó có thể đ•ợc xem xét ? - Khi nào quá trình lựa chọn ng•ời phát triển phải đ•ợc hòan tất ? - Khi nào dự án phải hoàn thành và khi nào các hợp đồng trung gian phải sẵn sàng ? - Ai, trong tổ chức, đ•ợc ủy thác trách nhiệm lựa chọn ng•ời phát triển ? - Mức ngân sách nào đ•ợc giành cho hợp đồng ? Tất cả những vấn đề trên phải đ•ợc nêu ra đầy đủ tr•ớc khi sang b•ớc sau: việc chuẩn bị các RFP. 3.3.2. Chuẩn bị các RFP. Yêu cầu tốt với đề nghị là yêu cầu sẽ lôi cuốn đ•ợc những đáp ứng tốt nhất (đề nghị). Chuẩn bị RFP tốt th•ờng đòi hỏi sự cộng tác của nhiều ng•ời, mỗi một ng•ời đ•ợc giao trách nhiệm về những phần đặc biệt của RFP. Một RFP phải bao gồm những phần sau: 1. Phát triển vấn đề và các mục tiêu dự án. Phần này cung cấp thông tin nền tảng chung, kể cả mô tả vấn đề cần đ•ợc giải quyết. Phần này phải cung cấp mọi chi tiết thích đáng cần thiết để hiểu vấn đề, kể cả biểu đồ, báo cáo và thí dụ. 2. Các yêu cầu kỹ thuật. Phần này mô tả những yêu cầu kỹ thuật đặc biệt của hệ thống nh•: - Các giao diện với các hệ thống hiện có 40
  41. Quản lý dự án phần mềm - Yêu cầu cơ sở dự liệu (nh• khả năng yêu cầu, các quan hệ dữ liệu v.v ) - Truyền thông và kiến trúc mạng - Các chuẩn quân sự, chuẩn chính quyền hay các chuẩn đ•ợc yêu cầu khác - Ph•ơng pháp luận phát triển yêu cầu - Độ tin cậy của hệ thống - Ràng buộc về thời gian - Ngôn ngữ lập trình - Máy tính chủ (host computer) 3. Thông tin quân sự Phần này cung cấp thông tin liên quan đến việc trình bày về thể chất đề nghị nh•: - Ai có thể trả lời cho RFP - Yêu cầu làm sáng tỏ và các thông tin bổ sung thế nào - Ngày tháng và địa điểm họp theo lịch với các nhà đề nghị - Chỉ tiêu lựa chọn đề nghị Phần này cũng có dự phòng về kết quả là tổ chức đ•a ra RFP sẽ không bị bắt buộc lựa chọn đề nghị chi phí thấp nhất hay bất cứ đề nghị nào khác. 4. Yêu cầu chi phí Mọi vấn đề tài chính đ•ợc nêu ở phần này. Điều này bao gồm cơ cấu giá yêu cầu trong đề nghị cũng nh• mọi thông tin đặc tr•ng đ•ợc nêu trong đề nghị (nh• giải trình chi phí tổng cộng hay lập giá riêng cho mỗi pha). Phần này cũng có thể nêu rõ loại hợp đồng phát triển nào đ•ợc chào (bản quyền, phí cộng thêm, giá cố định v.v ) 5. T• liệu tham khảo Phần này bao gồm danh sách mọi t• liệu nêu trong RFP nh• tiêu chuẩn, t• liệu hệ thống hiện có, tài liệu về sản phẩm khác v.v 6. Những thứ giao đ•ợc có yêu cầu Phần này bao gồm giải thích ban đầu về tuyến bố công việc (Sow). Chủ yếu đây là danh sách những thứ giao đ•ợc chính của dự án nh• t• liệu, phần mềm, đào tạo và mọi phần cứng hay thiết bị thích đáng. Phần này cũng thảo luận việc bảo đảm theo yêu cầu cho hệ thống sẽ đ•ợc giao. 7. Định dạng đề nghị yêu cầu Định dạng tiêu chuẩn yêu cầu cho đề nghị đ•ợc mô tả ở phần này. Điều này bao gồm nội dung yêu cầu về: - Đề nghị kỹ thuật - Đề nghị quản lý - Đề nghị về giá cả - Tuyên bố về công việc Thí dụ về một phác họa đề nghị có nêu ở phần 3.4 Phần này cũng bao gồm danh sách mọi thông tin có thể phụ lục cho dự án, ngoài đề nghị cơ bản (theo định dạng mô tả trên) nó có thể bao gồm 41
  42. Quản lý dự án phần mềm báo cáo tài chính mới nhất của tổ chức ng•ời đề nghị hay ủy nhiệm th• kỹ thuật của ng•ời đề nghị. 8. Đệ trình lịch trình và lịch quyết định Những thời hạn quyết định liên quan đến RFP đ•ợc mô tả ở phần này. Nó bao gồm thời gian chậm nhất cho việc đệ trình một đề nghị và ngày dự kiến tiến hành lựa chọn. Nó cũng có thể bao gồm lcịh trình mong muốn để hoàn thành công việc phát triển. Một trong những mục tiêu của RFP là làm cho nhiệm vụ so sánh các đề nghị đ•ợc dễ dàng. Nhiệm vụ này có thể trở nên cực kỹ khó nếu mọi đề nghị đ•ợc cấu tạo khác nhau hay nếu các đề nghị đó đ•ợc dựa trên những giả định rất khác nhau. Phần 3 của phác thảo nói đến cuộc họp với mọi ng•ời đề nghị. Cuộc họp này tạo cơ hội đảm bảo là mọi ng•ời đề nghị đều có một cơ sở chung về hiểu biết và kết quả trong các đề nghị của họ dễ so sánh hơn. Nó cũng thành đạt khi yêu cầu khuôn dạng đề nghị tiêu chuẩn hóa, nêu ở phần 7 của RFP. Bảng 3.1. có nêu phác thảo đại khái của một RFP. Bảng 3.1. Phác thảo khái quát cho một RFP 1. Tuyên bố vấn đề và mục tiêu dự án - Mô tả hiện trạng - T• liệu hỗ trợ các báo cáo các biểu đồ các thí dụ - Mô tả vấn đề - Các mục tiêu 2. Yêu cầu kỹ thuật - Giao diện với các hệ thống hiện có - Truyền thông và kiến trúc mạng - Độ tin cậy của hệ thống - Ngôn ngữ lập trình - Yêu cầu cơ sở dữ liệu - Tiêu chuẩn quân sự hay chính quyền - Ràng buộc thời gian - Máy tính chủ 3. Thông tin quản trị - Ai có thể đáp ứng cho RFP - Ngày tháng và địa điểm cuộc họp theo lịch với mọi ng•ời đề nghị ng•ời đ•ợc chọn- Làm sao yêu cầu sáng tỏ hay thông tin bổ sung - Tiêu chuẩn lựa chọn đề nghị - Các thông tin quản trị khác 4. Yêu cầu chi phí - Cơ cấu giá 42
  43. Quản lý dự án phần mềm các dịch vụ các sản phẩm cung cấp - Biện minh cho chi phí - Lập giá riêng từng pha - Loại hợp đồng phát triển đ•a chào - So sánh chi phí của các giải pháp thay thế 5. T• liệu tham khảo - Các tiêu chuẩn - T• liệu về hệ thống hiện có - T• liệu về sản phẩm 6. Yêu cầu chuyển giao - T• liệu - Phần mềm - Phần cứng hay thiết bị thích ứng - Bảo hành hệ thống sẽ chuyển giao - T• liệu về sản phẩm chuyển giao - Huấn luyện - Các công cụ phát triển và thử nghiệm 7. Định dạng đề nghị - Đề nghị kỹ thuật - Tuyên bố công việc - Đề nghị quản lý - Bổ sung và phụ lục + báo cáo tài chính của tổ chức đề nghị + ủy nhiệm th• kỹ thuật của ng•ời đề nghị + Tóm tắt nhân sự chủ lực - Đề nghị lập giá 8. Lịch đệ trình và lịch quyết định - Hạn cuối cùng phải đệ trình đề nghị - Hạn dự kiến tiến hành lựa chọn - Lịch mong muốn hoàn thành công việc phát triển 3.3.3. Phát yêu cầu đề xuất RFP Có pha ph•ơng pháp cơ bản trong phần phát một RFP - Theo một danh mục phân phát hạn chế - Theo một danh mục phân phát rộng - Cho mọi ai yêu cầu Danh mục phân phát hạn chế chỉ có những tổ chức nào đã đ•ợc lựa chọn theo bộ chỉ tiêu đặc tr•ng. Nhiều cơ quan chính phủ duy trì một 43
  44. Quản lý dự án phần mềm danh mục các công ty đ•ợc công nhận cho mỗi lớp RFP. Ph•ơng pháp này loại trừ các tổ chức ít có cơ may, đ•ợc lựa chọn. Danh mục phân phát rộng bao gồm bất cứ tổ chức nào có chút ít cơ may đ•ợc lựa chọn. Với một tổ chức đ•ợc bổ sung vào danh mục chỉ yêu cầu điều đó. Các danh mục phân phát rộng có thể thích hợp cho những dự án nhỏ, những dự án không đòi hỏi giám định đặc biệt nào hay những dự án mà ít tổ chức thích hợp đã nhắm vào. Không phải không phổ biến là thông tin RFP ban đầu đ•ợc quảng cáo trong báo chí hay tạp chí chuyên ngành. Những quảng cáo đã mô tả vắn tắt RFP và mời các công ty yêu cầu bản sao toàn bộ RFP. Sự tiếp cận này th•ờng là thích hợp khi phải tìm kiếm những ng•ời đề nghị tiềm ẩn mới. Bất kể ph•ơng pháp phân phát nào đ•ợc chọn lựa, tổ chức đề xuất RFP phải nhớ là thủ tục đề xuất không kết thúc cùng với sự phân phát RFP. Tổ chức phân phát phải sẵn sàng cung cấp mọi thông tin bổ sung và làm sáng tỏ những điều có thể đ•ợc yêu cầu. Có một cách để thực hiện điều này là (nh• đã nêu). Định lịch họp với mọi ng•ời đề nghị tiềm ẩn nhằm làm sáng tỏ và trả lời mọi câu hỏi. Cuộc họp này cũng là một cơ hội cho các ng•ời đề nghị đi xem một l•ợt các thiết bị mục tiêu và biết đ•ợc tận mắt những vấn đề sẽ đ•ợc dự án giải quyết. 3.4. đề xuất Các loại kiến nghị có thể phần thành 2 phạm trù cơ bản: - Kiến nghị do yêu cầu - Kiến nghị không yêu cầu Kiến nghị do yêu cầu đáp ứng hoặc RFP chính thức hoặc lời mời đặc biệt để trình kiến nghị trong khi kiến nghị không do yêu cầu thông th•ờng do ng•ời đề nghị x•ớng xuất. Tất nhiên có nhiều tổ hợp của hai biểu đó ví nh• tình huống kỳ dị nh•ng th•ờng thấy khi một kiến nghị không do yêu cầu làm nảy sinh việc đề xuất RFP chính thức. 3.4.1. Đề xuất không do yêu cầu Những kiến nghị không do yêu cầu ít chính thức hơn nhiều so với kiến nghị do yêu cầu và th•ờng không là gì hơn là một b•ớc đầu dẫn đến những th•ơng thảo chính thức hơn. Kiến nghị không do yêu cầu phải có những phần cơ bản sau: 1. Biện minh việc đệ trình kiến nghị 2. Mô tả vấn đề phải giải quyết 3. Mô tả giải pháp đề nghị 4. Mô tả tổ chức của ng•ời kiến nghị 5. Tổng quan chung về kinh phí của giải pháp đề nghị Phần biện minh là cốt tử vì nó giải thích vì sao khách hàng nên đọc tiếp. Phần này có thể nêu, chẳng hạn là ng•ời kiến nghị đã phát triển một công nghệ mới và thành công có lợi cho khách hàng và có thể thích nghi với nhu cầu của (tổ chức) khách hàng. Mục tiêu chính là cung cấp câu trả 44
  45. Quản lý dự án phần mềm lời cho câu hỏi của khách hàng: “Vì sao công ty lại tiếp cận tôi và vì sao đọc kiến nghị này là lợi ích cho tôi vậy ?” Các phần 2 và 3, mô tả cách mà kiến thức chuyên môn hóa của ng•ời đề nghị đ•ợc vận dụng vào các vấn đề của tổ chức khách hàng. Điều này đòi hỏi ng•ời đề nghị nghiên cứu tổ chức của khách hàng nhằm đảm bảo là kiến nghị cung cấp một giải pháp thực cho một vấn đề thực. Chi phí chính xác của giải pháp không cần nêu ở giai đoạn này. Một kiến nghị không do yêu cầu hiến khi đ•ợc chấp nhận ngày vòng đầu. Mục tiêu chính của nó là tạo dựng một mối quan tâm. Nếu kiến nghị tạo đủ mối quan tâm thì ng•ời đề nghị sẽ đ•ợc mời thảo luận kiến nghị đó và sau đó sẽ đệ trình lại cho khách hàng một bản trình bày kiến nghị chi tiết hơn. 3.4.2. Đề xuất khi có yêu cầu Kiến nghị do yêu cầu mà khách hàng x•ớng xuất coi nh• đáp lại RFP chính thức hay một hình thức mời nào khác đệ trình kiến nghị. Trái với tính chất không chính thức của kiến nghị không do yêu cầu, kiến nghị do yêu cầu là hoàn chỉnh và chi tiết và nội dung th•ờng ràng buộc cho ng•ời đề nghị (kiến nghị coi nh• văn bản ràng buộc đ•ợc thảo luận thêm và minh họa ở lời nói đầu ch•ơng 10). Cùng với yêu cầu đệ trình kiến nghị, khách hàng cũng có thể dẫn chính xác kiến nghị phải đ•ợc chuẩn bị thể bào và đệ trình ra sao. Một thí dụ về dạng kiến nghị chính thức có ở bảng 3.2. Một lĩnh vực cơ bản khiến kiến nghị do yêu cầu và không do yêu cầu khác nhau là ở nhu cầu cạnh tranh. Các kiến nghị do yêu cầu phải có khả năng cạnh tranh thắng lợi với các kiến nghị khác. Điều này có nghĩa là việc chuẩn bị kiến nghị do yêu cầu phải đ•ợc coi bản thân nó là một dự án mini và nh• thế đòi hỏi hình thành một đội ngũ chuẩn bị kiến nghị. 3.4.3. Đội ngũ chuẩn bị đề xuất. Việc hình thành ban kiến nghị là cơ bản cho bất cứ tổ chức nào dự tính đáp ứng thành công một RFP. Ban này chỉ định ng•ời có nhiệm vụ định vị những RFP thích hợp và độ trình để thảo luận căn cứ đ•ờng lỗi chỉ đạo do ban đề ra. Đ•ờng lối chỉ đạo phải nhằm vào các RFP mà: - nằm trong phạm vi đ•ờng lỗi kinh doanh của công ty - nằm trong phạm vị giới hạn kích th•ớc đặc tr•ng (dự án không quá nhỏ và không quá lớn). - không hiển nhiên loại trừ chính công ty (thí dụ yêu cầu giám định đặc biệt hay hoàn thành về an ninh). Căn cứ ở đánh giá của ban về các RFP đek trình, ban kiến nghị quyết định RFP nào là đáp ứng đ•ợc bởi công ty. Sau đó ban kiến nghị lựa chọn đội ngũ chuẩn bị cho mỗi kiến nghị. Đội ngũ này có thể chỉ có một ng•ời hay nhiều thành viên, tùy thuộc ở qui mô của dự án kiến nghị. Đội ngũ rút từ kinh nghiệm và giám định của 45
  46. Quản lý dự án phần mềm mọi nhân viên công ty và nếu cần có thể sử dụng dịch vụ của các chuyên gia bên ngoài hỗ trợ trong việc chuẩn bị kiến nghị. Kiến nghị cơ bản yêu cầu trong phạm vi đội ngũ chuẩn bị kiến nghị bao gồm: - Kiến thức kỹ thuật liên quan đến mỗi lĩnh vực riêng rẽ do kiến nghị l•u ý - Quản lý dự án kể cả dự toán và lập kế hoạch - Kiến thức tài chính, kể cả định ngân sách và lập kế hoạch tài chính cho toàn bộ dự án - Quen thuộc với tổ chức của khách hàng - Kinh nghiệm trong soạn thảo kiến nghị Một thành viên của đội ngũ sẽ đ•ợc ban chỉ định lãnh đạo đội hay điều phối viên. Sau khi đội ngũ đã hình thành, hai việc ủy thác đầu tiên của nó là: 1. Duyệt xét b•ớc đầu RFP 2. Chuẩn bị lịch trình cho việc hoàn thành dự án và giao trách nhiệm. Việc chuẩn bị kiến nghị tốt tốn tiền và phải đ•ợc coi nh• là một đầu t•. Nừu việc này làm tốt, nó có thể tạo ra lợi nhuận, ngân sách kiến nghị không thích hợp sẽ giảm cơ may tạo ra kiến nghị thắng đ•ợc các thành viên của đội ngũ chuẩn bị kiến nghị phải đ•ợc tập trung vào nhiệm vụ và họ phải đ•ợc cung cấp nguồn lực thích hợp. Theo Silver (1986), các kiến nghị trong công nghệ cao và các công nghiệp hành không vũ trụ đ•ợc cấp ngân sách khoảng 2% trị giá hợp đồng, dù sao, phạm vi chi phí. Kiến nghị là 1% đến 10%. Chi phí hợp đồng càng cao, phần trăm dành cho chuẩn bị kiến nghị càng thấp.6 3.4.4. Khuôn dạng đề xuất Kiến nghị tốt phải trả lời đ•ợc 6 câu hỏi cơ bản: ai, cái gì. tại sao, thế nào, khi nào, và bao nhiêu. Đáp án cho các câu hỏi đó đơn giản liên quan đến: 1. Ai là tổ chức đệ trình kiến nghị ? 2. Cái gì đ•ợc đề nghị ? 3. Tại sao kiến nghị đ•ợc đệ trình ? 4. Làm sao công việc kiến nghị đ•ợc thực hiện ? 5. Khi nào nó sẽ đ•ợc phát triển xong và bàn giao ? 6. Bao nhiêu chi phí ? 6 Silver đ•a ra, phạm vi hợp đồng dự án $10K đén $2B với phạm vi chi phí kiến nghị từ 1% đến 20% ở Hoa Kỳ và phạm vi hợp đồng $10K đến $1B với phạm vi chi phí kiến nghị 1% đến 10% ở Châu Âu. Căn cứ ở hầu hết các dự án khoảng $250K và $100, ông dựa ra phạm vi chi phí kiến nghị từ 1,5% đến 8% ở Hoa kỳ và 1% đến 2 1/2% ở châu Âu. 46
  47. Quản lý dự án phần mềm Câu hỏi tại sao là quan trọng cho một kiến nghị không do yêu cầu và tạo cơ sở cho việc đệ trình nó. Đáp án cho một RFP chỉ cần khẳng định  Kiến nghị này đ•ợc đệ trình để phúc đáp yêu cầu đ•ợc kiến nghị cuả công ty Acme Inc số 456 ngày 5/6 . Năm câu hỏi khác đ•ợc nhằm vào 5 hợp phần chính của kiến nghị 1. Kiến nghị kỹ thuật (cái gì, làm sao) 2. Kiến nghị quản lý (làm sao, khi nào) 3. Kiến nghị định giá (bao nhiêu) 4. Tuyên bố công việc (cái gì, khi nào) 5. Tóm tắt điều hành và trong phần bổ sung bao gồm: - Nền tảng và kinh nghiệm của công ty (ai) - Trình độ chuyên môn của nhân sự chủ lực - Các chứng vật và văn bản thích hợp Bảng 3.2. Một khái lựợc cho một kiến nghị kỹ thuật 1. Tổng quan về vấn đề cần giải quyết 2. Tổng quan về giải pháp kiến nghị 3. Hợp phần cần mua 4. Hợp phần cần phát triển 5. Thiết bị - Cơ sở hạ tầng - Phần cứng máy tính - Truyền thông và mạng - Thiết bị thử và kiển nghiệm - Thiết bị đặc biệt khác - Giao diện với các hệ khác 6. Hợp phần phần mềm - Mô tả chung hệ phần mềm - Mô tả chi tiết từng hợp phần, phần mềm chủ yếu - Các giao diện với các hệ khác - Các cơ sở dữ liệu - Sử dụng các hợp phần, phần mềm hiện có - Khả năng sử dụng lại các hợp phần, phần mềm cần phát triển 7. Công trình nhân văn và giao diện ng•ời sử dụng 8. Nhận xét đặc biệt - Độ tin - Đúng thời gian - Tích hợp dữ liệu - Sao l•u và thu hồi 47
  48. Quản lý dự án phần mềm Bảng 3.3. Một khái l•ợc cho kiến nghị quản lý 1. Công cụ và tiện ích phát triển 2. Môi tr•ờng phát triển 3. Yêu cầu nhân sự và cơ cấu đội ngũ phát triển 4. Ph•ơng pháp luận phát triển 5. Các pha phát triển 6. Xét duyệt 7. Báo cáo - Các loại báo cáo - Khuôn dạng báo cao - Chu kỳ báo cáo - Danh mục phân phối 8. Các chủ thầu phụ 9. Các tiêu chuẩn 10. Thử nghiệm: - Các giai đoạn thử nghiệm - Thủ tục thử nghiệm chính thức - Phát hiện và hiệu chỉnh sai 11. Kiểm tra chất l•ợng 12. Quản lý cấu hình 13. Bảo d•ỡng 14. Lịch - Danh mục hoạt động chủ yêu - Các cột mốc - Các phụ thuộc - Bố trí và cung cấp nhân lực 15. Quản lý rủi ro Bảng 3.4. mẫu khái l•ợc cho kiến nghị định giá 1. Loại hợp đồng (phí cộng thêm, giá cố định v.v ) 2. Chi phí phát triển do hợp đồng phần dự án 3. Các chi phí chủ thầu phụ 4. Các chi phí mua sắm 5. Tổng phí 6. Bảo hành 7. Lợi nhuận 8. Tổng chi phí dự án 9. Loại tài trợ (không có, có) 10. Lịch thanh toán 11. Lập hóa đơn và quản trị 48