First, can I stress that this is a question about the process of debugging and not a specific error. As a React/Redux newbie from time-to-time I get a React project that will not 'compile' with a typical error being something like this:
{ Error: Cannot find module 'redux' from 'C:\Users\abcde\Documents\ReactTest\node_modules\react-redux\lib\utils'
at C:\Users\abcde\Documents\ReactTest\node_modules\browser-resolve\node_modules\resolve\lib\async.js:46:17
at process (C:\Users\abcde\Documents\ReactTest\node_modules\browser-resolve\node_modules\resolve\lib\async.js:173:43)
at ondir (C:\Users\abcde\Documents\ReactTest\node_modules\browser-resolve\node_modules\resolve\lib\async.js:188:17)
at load (C:\Users\abcde\Documents\ReactTest\node_modules\browser-resolve\node_modules\resolve\lib\async.js:69:43)
at onex (C:\Users\abcde\Documents\ReactTest\node_modules\browser-resolve\node_modules\resolve\lib\async.js:92:31)
at C:\Users\abcde\Documents\ReactTest\node_modules\browser-resolve\node_modules\resolve\lib\async.js:22:47
at FSReqWrap.oncomplete (fs.js:123:15)
stream:
Labeled {
_readableState:
ReadableState {
objectMode: true,
highWaterMark: 16,
buffer: [Object],
length: 0,
pipes: [Object],
pipesCount: 1,
flowing: true,
ended: false,
endEmitted: false,
reading: true,
sync: false,
needReadable: true,
emittedReadable: false,
readableListening: false,
resumeScheduled: false,
defaultEncoding: 'utf8',
ranOut: false,
awaitDrain: 0,
readingMore: false,
decoder: null,
encoding: null },
readable: true,
domain: null,
_events:
{ end: [Object],
error: [Object],
data: [Function: ondata],
_mutate: [Object] },
_eventsCount: 4,
_maxListeners: undefined,
_writableState:
WritableState {
objectMode: true,
highWaterMark: 16,
needDrain: false,
ending: true,
ended: true,
finished: true,
decodeStrings: true,
defaultEncoding: 'utf8',
length: 0,
writing: false,
corked: 0,
sync: false,
bufferProcessing: false,
onwrite: [Function],
writecb: null,
writelen: 0,
bufferedRequest: null,
lastBufferedRequest: null,
pendingcb: 0,
prefinished: true,
errorEmitted: false,
bufferedRequestCount: 0,
corkedRequestsFree: [Object] },
writable: false,
allowHalfOpen: true,
_options: { objectMode: true },
_wrapOptions: { objectMode: true },
_streams: [ [Object] ],
length: 1,
label: 'deps' } }
This does not seem to give any pointers as to where the error is, merely what it is. What would be the correct method to determine where the error lies?